Redis解決Session共享問題的方法詳解
企業(yè)項目中,一般都是將項目部署到多臺服務(wù)器上,用nginx做負載均衡。這樣可以減輕單臺服務(wù)器的壓力,不過這樣也帶來一些問題,例如之前單機部署的話,session存取都是直接了當(dāng)?shù)?,因為請求就只到這一臺服務(wù)器上,不需要考慮數(shù)據(jù)共享。接下來分別用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)) { //獲取當(dāng)前服務(wù)端口 port = environment.getProperty("local.server.port"); request.getSession().setAttribute("port", port); } log.info("session-port: {}", port); return HttpResult.success(port); } }
進入swagger的接口文檔頁面,進行測試接口請求:
8000端口控制臺輸出:
然后請求8001的同一個接口:
從上面兩張圖可以看出雖然是同一套代碼,去session里獲取的同一個參數(shù),2個端口獲取的值卻不同,這就是分布式中需要解決的問題:數(shù)據(jù)共享。
之前的文章有講過用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 # 設(shè)置session失效時間 store-type: redis # 修改spring-session存儲配置,默認存儲到服務(wù)器內(nèi)存中,現(xiàn)在設(shè)置存到redis中(關(guān)鍵)
其實這里也可以設(shè)置session的過期時間,為了和上面的作對比,此處設(shè)置過期時間為2小時。
無需修改代碼,重新啟動2個端口,再分別請求同一個接口:
8000端口控制臺輸出:
8001端口控制臺輸出:
再看redis:
另外值得注意的是,當(dāng)上面2處都配置session過期時間時,實際是以spring下的配置為準的。
以上就是Redis解決Session共享問題的方法詳解的詳細內(nèi)容,更多關(guān)于Redis解決Session共享的資料請關(guān)注本站其它相關(guān)文章!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。