在單體項目中,我們將用戶信息存在 session 中,那么在該 session 過期之前,我們都可以從 session 中獲取到用戶信息,通過登錄攔截,進行操作
但是分布式部署的時候,我們請求的服務器可能不是同一臺服務器,那么我們就必須要面對 session 共享的問題,下面介紹的是在 SpringBoot 實現 session 共享的方式
一、創建項目
創建 SpringBoot 項目,選擇 Maven 依賴
最終 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 中取出信息
四、打包測試
啟動項目,分別啟動在兩個端口:
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
我們從 8080 端口,將信息保存在 session 中
我們訪問:http://localhost:8081/get
我們在 8081 端口的項目中從 session 中取出了內容:hello world~~~
由此證明,我們的 session 共享已經成功
五、分布式部署
下面我們借助 Nginx 代理轉發訪問這兩個項目
1、配置轉發
nginx 配置文件如下:
主要配置內容:
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 里面剛剛測試保存的信息
然后我們訪問:
http://localhost/set
這里我們可以看出,由 8080 端口的服務器完成了 set 請求,多次訪問,nginx 將會根據什么配置的權重參數分配服務器來完成操作
下面我們訪問:
http://localhost/get
可以看出,由 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