日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

在單體項目中,我們將用戶信息存在 session 中,那么在該 session 過期之前,我們都可以從 session 中獲取到用戶信息,通過登錄攔截,進行操作
但是分布式部署的時候,我們請求的服務器可能不是同一臺服務器,那么我們就必須要面對 session 共享的問題,下面介紹的是在 SpringBoot 實現 session 共享的方式

一、創建項目

創建 SpringBoot 項目,選擇 Maven 依賴

SpringBoot如何用Session共享實現分布式部署?

 


SpringBoot如何用Session共享實現分布式部署?

 

最終 pom.xml 文件如下:

<!-- redis的依賴 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<!-- web的依賴 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- session共享的依賴 -->
<dependency>
    <groupId>org.springframework.session</groupId>
    <artifactId>spring-session-data-redis</artifactId>
</dependency>

二、配置 Redis

我們需要借助 redis 實現 session 共享,所以我們需要在配置文件中配置 redis 的信息

server:
  port: 8080

spring:
  redis:
    host: 127.0.0.1
    port: 6379
    database: 0
    password:

我們配置了該項目的端口,以及 redis 的連接信息

三、寫接口

package com.zyxx.session.controller;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMApping;
import org.springframework.web.bind.annotation.RestController;

import JAVAx.servlet.http.HttpSession;

@RestController
public class DemoController {

    /**
     * 獲取項目端口
     */
    @Value("${server.port}")
    private String port;

    /**
     * 將信息存放在session中
     */
    @GetMapping("set")
    public String set(HttpSession session) {
        session.setAttribute("user", "hello world~~~");
        return port;
    }

    /**
     * 從session中獲取信息
     */
    @GetMapping("get")
    public String get(HttpSession session) {
        return session.getAttribute("user") + " : " + port;
    }
}

我們寫了一個 set,一個 get 方法,將信息存放在 session 中,從 session 中取出信息

四、打包測試

SpringBoot如何用Session共享實現分布式部署?

 

啟動項目,分別啟動在兩個端口:

java -jar .session-0.0.1-SNAPSHOT.jar --server.port=8080
java -jar .session-0.0.1-SNAPSHOT.jar --server.port=8081

分別啟動在 8080,8081端口

訪問:http://localhost:8080/set

SpringBoot如何用Session共享實現分布式部署?

 

我們從 8080 端口,將信息保存在 session 中

我們訪問:http://localhost:8081/get

SpringBoot如何用Session共享實現分布式部署?

 

我們在 8081 端口的項目中從 session 中取出了內容:hello world~~~

由此證明,我們的 session 共享已經成功

五、分布式部署

下面我們借助 Nginx 代理轉發訪問這兩個項目

1、配置轉發

nginx 配置文件如下:

SpringBoot如何用Session共享實現分布式部署?

 

主要配置內容:

upstream helloworld{
	server 127.0.0.1:8080 weight=1;
	server 127.0.0.1:8081 weight=2;
}

這里配置轉發到 8080,8081 端口,并配置了權重

location / {
	proxy_pass http://helloworld;
    #root   html;
    #index  index.html index.htm;
}

攔截本地的所有請求,默認端口為 80

2、啟動 nginx

nginx -s reload

3、訪問測試

我們先刪除 redis 里面剛剛測試保存的信息

SpringBoot如何用Session共享實現分布式部署?

 

然后我們訪問:

http://localhost/set
SpringBoot如何用Session共享實現分布式部署?

 

這里我們可以看出,由 8080 端口的服務器完成了 set 請求,多次訪問,nginx 將會根據什么配置的權重參數分配服務器來完成操作

下面我們訪問:

http://localhost/get
SpringBoot如何用Session共享實現分布式部署?

 

可以看出,由 8081 端口的服務器完成了 get 請求,并成功取到了存在 session 中的數據,實現了 session 共享

六、總結

1、以前我們在 SSM 架構的項目中實現 session 共享,需要配置三個地方 ,一個是 web.xml 配置代理過濾器,然后在 Spring 容器中配置 Redis,最后再配置 Spring Session,相比 SpringBoot,稍有復雜
2、我們在 SpringBoot 中實現 session 共享還是非常簡單的,只需要引入依賴,簡單配置即可實現
3、實現 session 共享,幫助我們將項目分布式部署,提升服務性能有很大的意義

作者: Asurplus、

原文鏈接:https://lizhou.blog.csdn.net/article/details/106676823

分享到:
標簽:SpringBoot Session
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定