Redis解決Session共享問(wèn)題的方法詳解
企業(yè)項(xiàng)目中,一般都是將項(xiàng)目部署到多臺(tái)服務(wù)器上,用nginx做負(fù)載均衡。這樣可以減輕單臺(tái)服務(wù)器的壓力,不過(guò)這樣也帶來(lái)一些問(wèn)題,例如之前單機(jī)部署的話,session存取都是直接了當(dāng)?shù)?,因?yàn)檎?qǐng)求就只到這一臺(tái)服務(wù)器上,不需要考慮數(shù)據(jù)共享。接下來(lái)分別用8000和8001端口啟動(dòng)同一個(gè)項(xiàng)目,做一個(gè)簡(jiǎn)單演示:
測(cè)試接口代碼:
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 = "測(cè)試接口") @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過(guò)期時(shí)間: {}秒", 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); } }
進(jìn)入swagger的接口文檔頁(yè)面,進(jìn)行測(cè)試接口請(qǐng)求:
8000端口控制臺(tái)輸出:
然后請(qǐng)求8001的同一個(gè)接口:
從上面兩張圖可以看出雖然是同一套代碼,去session里獲取的同一個(gè)參數(shù),2個(gè)端口獲取的值卻不同,這就是分布式中需要解決的問(wèn)題:數(shù)據(jù)共享。
之前的文章有講過(guò)用redis做分布式鎖,其實(shí)這里也可以用redis解決session共享的問(wèn)題。
在引入redis之前,先簡(jiǎn)單貼一下怎么在配置文件里修改session默認(rèn)過(guò)期時(shí)間。從上圖可以看到session默認(rèn)過(guò)期時(shí)間是1800秒,也就是30分鐘,如果想要延長(zhǎng),可以在配置文件application.yml中修改:
server: port: 8000 servlet: session: timeout: 3600 #延長(zhǎng)session過(guò)期時(shí)間到1小時(shí)
回歸正題,要用redis解決session共享,首先需要引入依賴(lài)包:
<!--springboot中的redis依賴(lài)--> <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失效時(shí)間 store-type: redis # 修改spring-session存儲(chǔ)配置,默認(rèn)存儲(chǔ)到服務(wù)器內(nèi)存中,現(xiàn)在設(shè)置存到redis中(關(guān)鍵)
其實(shí)這里也可以設(shè)置session的過(guò)期時(shí)間,為了和上面的作對(duì)比,此處設(shè)置過(guò)期時(shí)間為2小時(shí)。
無(wú)需修改代碼,重新啟動(dòng)2個(gè)端口,再分別請(qǐng)求同一個(gè)接口:
8000端口控制臺(tái)輸出:
8001端口控制臺(tái)輸出:
再看redis:
另外值得注意的是,當(dāng)上面2處都配置session過(guò)期時(shí)間時(shí),實(shí)際是以spring下的配置為準(zhǔn)的。
以上就是Redis解決Session共享問(wèn)題的方法詳解的詳細(xì)內(nèi)容,更多關(guān)于Redis解決Session共享的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
緩存替換策略及應(yīng)用(以Redis、InnoDB為例)
本文以Redis、InnoDB為例給大家講解緩存替換策略及應(yīng)用,本文給大家提到五種置換策略,通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-07-07redis.conf中使用requirepass不生效的原因及解決方法
本文主要介紹了如何啟用requirepass,以及啟用requirepass為什么不會(huì)生效,從代碼層面分析了不生效的原因,以及解決方法,需要的朋友可以參考下2023-07-07redis中的數(shù)據(jù)結(jié)構(gòu)和編碼詳解
本文主要和大家分享幾種Redis數(shù)據(jù)結(jié)構(gòu)詳解,希望文中的案例和代碼,能幫助到大家。2020-03-03攔截Redis命令導(dǎo)致的Lua腳本執(zhí)行失敗的問(wèn)題解決
本文主要介紹了攔截Redis命令導(dǎo)致的Lua腳本執(zhí)行失敗的問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06redis中RedissonLock如何實(shí)現(xiàn)等待鎖的
本文主要介紹了redis中RedissonLock如何實(shí)現(xiàn)等待鎖的,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11Redis設(shè)置密碼的實(shí)現(xiàn)步驟
本文主要介紹了Redis設(shè)置密碼的實(shí)現(xiàn)步驟,主要包括兩種方法:臨時(shí)密碼和持久密碼,具有一定的參考價(jià)值,感興趣的可以了解一下2023-08-08