網站首頁 編程語言 正文
? 企業項目中,一般都是將項目部署到多臺服務器上,用nginx做負載均衡。這樣可以減輕單臺服務器的壓力,不過這樣也帶來一些問題,例如之前單機部署的話,session存取都是直接了當的,因為請求就只到這一臺服務器上,不需要考慮數據共享。接下來分別用8000和8001端口啟動同一個項目,做一個簡單演示:
測試接口代碼:
package com.wl.standard.controller;
import cn.hutool.core.util.StrUtil;
import com.wl.standard.common.result.HttpResult;
import io.swagger.annotations.Api;
import lombok.extern.slf4j.Slf4j;
import org.springframework.core.env.Environment;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
/**
* @author wl
* @date 2022/7/10 14:25
*/
@Api(tags = "測試接口")
@Slf4j
@RestController
@RequestMapping("/test")
public class TestController {
@Resource
Environment environment;
@GetMapping("/demo")
public HttpResult demo(HttpServletRequest request) {
int maxInactiveInterval = request.getSession().getMaxInactiveInterval();
log.info("session過期時間: {}秒", maxInactiveInterval);
String port = (String) request.getSession().getAttribute("port");
if (StrUtil.isEmpty(port)) {
//獲取當前服務端口
port = environment.getProperty("local.server.port");
request.getSession().setAttribute("port", port);
}
log.info("session-port: {}", port);
return HttpResult.success(port);
}
}
?
進入swagger的接口文檔頁面,進行測試接口請求:
?8000端口控制臺輸出:
?
?然后請求8001的同一個接口:
從上面兩張圖可以看出雖然是同一套代碼,去session里獲取的同一個參數,2個端口獲取的值卻不同,這就是分布式中需要解決的問題:數據共享。
之前的文章有講過用redis做分布式鎖,其實這里也可以用redis解決session共享的問題。
在引入redis之前,先簡單貼一下怎么在配置文件里修改session默認過期時間。從上圖可以看到session默認過期時間是1800秒,也就是30分鐘,如果想要延長,可以在配置文件application.yml中修改:
server:
port: 8000
servlet:
session:
timeout: 3600 #延長session過期時間到1小時
?回歸正題,要用redis解決session共享,首先需要引入依賴包:
<!--springboot中的redis依賴-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-data-redis</artifactId>
</dependency>
然后還需要在配置文件中配置:
spring:
# session配置
session:
timeout: 7200 # 設置session失效時間
store-type: redis # 修改spring-session存儲配置,默認存儲到服務器內存中,現在設置存到redis中(關鍵)
其實這里也可以設置session的過期時間,為了和上面的作對比,此處設置過期時間為2小時。
無需修改代碼,重新啟動2個端口,再分別請求同一個接口:
8000端口控制臺輸出:
8001端口控制臺輸出:
?
再看redis:
?
另外值得注意的是,當上面2處都配置session過期時間時,實際是以spring下的配置為準的。
?
原文鏈接:https://blog.csdn.net/wl_Honest/article/details/125708850
相關推薦
- 2022-03-27 C++引用和指針的區別你知道嗎_C 語言
- 2022-05-13 linq中的聚合操作符_實用技巧
- 2022-12-10 一文帶你快速了解C/C++標準庫中的ptrdiff_t_C 語言
- 2023-11-19 樹莓派/arm設備上安裝火狐Firefox瀏覽器
- 2023-07-18 SpringBoot中無法用@Value獲取yml中的配置值的原因
- 2023-11-13 【云原生】docker-compose安裝,解決Warning: the “docker“ comm
- 2022-08-18 C/C++中的new和delete的實現過程小結_C 語言
- 2022-05-13 Flutter開發之——getX-GetPage中間件(11)
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支