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共享還是很簡單得到。