SpringBoot2.x系列教程74--SpringBoot中實現分佈式的Session共享

SpringBoot2.x系列教程74--SpringBoot中實現分佈式的Session共享

一. SpringBoot中實現Session共享

1. 創建web項目

我們按照之前的經驗,創建一個web程序,並將之改造成Spring Boot項目,具體過程略。

 

2.添加依賴包

<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>
 <dependency>
     <groupId>org.springframework.session</groupId>
     <artifactId>spring-session-core</artifactId>
 </dependency>

3.創建application.yml文件

server:
   port: 8080
 #配置redis
 spring:
   redis:
     host: 127.0.0.1
     port: 6379
     #password: 123456
     jedis:
       pool:
         max-idle: 8
         min-idle: 0
         max-active: 8
         #max-wait: 60000
     #timeout: 3000 #超時一定要大於0
   session:
     #設置session存儲類型
     store-type: redis
這裏可以設置多種session的store-type:

我們這裏選擇利用redis來對session進行集中存儲,實現session共享。

4.創建Session配置類

package com.yyg.boot.config;

import org.springframework.context.annotation.Configuration;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;

/**
 * @Author 一一哥Sun
 * @Date Created in 2020/4/28
 * @Description 開啓Redis Http Session
 */
@Configuration
@EnableRedisHttpSession(maxInactiveIntervalInSeconds = 3600)
public class RedisHttpSessionConfiguration {

}

在這裏添加@EnableRedisHttpSession註解,可以通過maxInactiveIntervalInSeconds屬性設置Session的過期時間。

5.創建一個Controller接口方法

該接口方法當用戶不存在時提示“用戶不存在”,否則會提示“用戶存在”。

package com.yyg.boot.web;

import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;

/**
 * @Author 一一哥Sun
 * @Date Created in 2020/4/28
 * @Description Description
 */
@Slf4j
@RestController
public class SessionController {

    @RequestMapping("/session")
    public Object springSession(@RequestParam("username") String username, HttpServletRequest request, HttpSession session) {
        Cookie[] cookies = request.getCookies();
        if (cookies != null && cookies.length > 0) {
            for (Cookie cookie : cookies) {
                log.warn(cookie.getName() + "=" + cookie.getValue());
            }
        }

        Object value = session.getAttribute("username");
        if (value == null) {
            log.warn("用戶不存在");
            //保存session
            session.setAttribute("username", "{username: '" + username + "', age: 30}");
        } else {
            log.warn("用戶存在");
        }

        return "username=" + value;
    }

}

6.創建入口類

package com.yyg.boot;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 * @Author 一一哥Sun
 * @Date Created in 2020/4/28
 * @Description Description
 */
@SpringBootApplication
public class SpringSessionApplication {

    public static void main(String[] args){
        SpringApplication.run(SpringSessionApplication.class,args);
    }

}

7.完整項目結構

8.啓動項目進行測試

第一次在瀏覽器中進行訪問,會看到瀏覽器中的username=null,並且控制檯中展示的log信息爲“用戶不存在”,說明此時還沒有創建出session。但是當第一次訪問之後,session就被創建出來了,並且被存儲到了redis中,實現了持久化存儲。可以看如下圖:

第二次訪問,就會看到username已經可以獲取到新的信息了。

log控制檯中也看到已經提示“用戶存在”的信息了。

並且我們可以看到Redis控制檯中,提示了TTL過期時間是3660,每隔1秒鐘刷新1次,3600秒後過期。

此時我們可以分別啓動一個8080和8081進程,在兩個進程上分別測試session接口。

#進入到項目的target目錄下,執行java -jar命令,部署我們的jar包

F:\onlineWorks\boot-demos\demo43_springsession\target>java -jar demo43_springsession-1.0-SNAPSHOT.jar --server.port=8080

F:\onlineWorks\boot-demos\demo43_springsession\target>java -jar demo43_springsession-1.0-SNAPSHOT.jar --server.port=8081

在瀏覽器中,我們的8080和8081端口上訪問時,可以看到有一個共同的Session信息:

可以看到在兩個不同的進程端口上,都分別訪問到了同一個session信息,說明我們實現了分佈式進程中session共享。可見在有了Spring Session後,實現session共享還是很簡單得到。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章