欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redis解決Session共享問題的方法詳解

 更新時間:2022年07月11日 09:45:54   作者:wl_Honest  
這篇文章主要為大家詳細介紹了分布式系統(tǒng)Redis解決Session共享問題的方法,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下

企業(yè)項目中,一般都是將項目部署到多臺服務(wù)器上,用nginx做負載均衡。這樣可以減輕單臺服務(wù)器的壓力,不過這樣也帶來一些問題,例如之前單機部署的話,session存取都是直接了當?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)) {
            //獲取當前服務(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:

另外值得注意的是,當上面2處都配置session過期時間時,實際是以spring下的配置為準的。

以上就是Redis解決Session共享問題的方法詳解的詳細內(nèi)容,更多關(guān)于Redis解決Session共享的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Redis的KEYS 命令千萬不能亂用

    Redis的KEYS 命令千萬不能亂用

    這篇文章主要介紹了Redis的KEYS 命令千萬不能亂用,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • 緩存替換策略及應(yīng)用(以Redis、InnoDB為例)

    緩存替換策略及應(yīng)用(以Redis、InnoDB為例)

    本文以Redis、InnoDB為例給大家講解緩存替換策略及應(yīng)用,本文給大家提到五種置換策略,通過實例代碼給大家介紹的非常詳細,需要的朋友參考下吧
    2021-07-07
  • redis.conf中使用requirepass不生效的原因及解決方法

    redis.conf中使用requirepass不生效的原因及解決方法

    本文主要介紹了如何啟用requirepass,以及啟用requirepass為什么不會生效,從代碼層面分析了不生效的原因,以及解決方法,需要的朋友可以參考下
    2023-07-07
  • redis中的數(shù)據(jù)結(jié)構(gòu)和編碼詳解

    redis中的數(shù)據(jù)結(jié)構(gòu)和編碼詳解

    本文主要和大家分享幾種Redis數(shù)據(jù)結(jié)構(gòu)詳解,希望文中的案例和代碼,能幫助到大家。
    2020-03-03
  • 攔截Redis命令導(dǎo)致的Lua腳本執(zhí)行失敗的問題解決

    攔截Redis命令導(dǎo)致的Lua腳本執(zhí)行失敗的問題解決

    本文主要介紹了攔截Redis命令導(dǎo)致的Lua腳本執(zhí)行失敗的問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • 一文弄懂Redis單線程和多線程

    一文弄懂Redis單線程和多線程

    本文主要介紹了一文弄懂Redis單線程和多線程,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • redis中RedissonLock如何實現(xiàn)等待鎖的

    redis中RedissonLock如何實現(xiàn)等待鎖的

    本文主要介紹了redis中RedissonLock如何實現(xiàn)等待鎖的,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • 淺談Redis內(nèi)存回收策略

    淺談Redis內(nèi)存回收策略

    本文主要介紹了淺談Redis內(nèi)存回收策略,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • Redis設(shè)置密碼的實現(xiàn)步驟

    Redis設(shè)置密碼的實現(xiàn)步驟

    本文主要介紹了Redis設(shè)置密碼的實現(xiàn)步驟,主要包括兩種方法:臨時密碼和持久密碼,具有一定的參考價值,感興趣的可以了解一下
    2023-08-08
  • redis批量刪除key的步驟

    redis批量刪除key的步驟

    本文分享最新版Redis批量刪除key的方法,希望能幫到遇到同樣問題的網(wǎng)友。
    2020-09-09

最新評論