1. 程式人生 > 程式設計 >SpringBoot中實現分散式的Session共享的詳細教程

SpringBoot中實現分散式的Session共享的詳細教程

一. SpringBoot中實現Session共享

1. 建立web專案

我們按照之前的經驗,建立一個web程式,並將之改造成Spring Boot專案,具體過程略。

SpringBoot中實現分散式的Session共享的詳細教程

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:

SpringBoot中實現分散式的Session共享的詳細教程

我們這裡選擇利用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 - 這個網站可出售。 - 最佳的springapplication 來源和相關資訊。(SpringSessionApplication.class,args);
 }
 
}

7.完整專案結構

SpringBoot中實現分散式的Session共享的詳細教程

8.啟動專案進行測試

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

SpringBoot中實現分散式的Session共享的詳細教程

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

SpringBoot中實現分散式的Session共享的詳細教程

log控制檯中也看到已經提示“使用者存在”的資訊了。

SpringBoot中實現分散式的Session共享的詳細教程

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

SpringBoot中實現分散式的Session共享的詳細教程

此時我們可以分別啟動一個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

SpringBoot中實現分散式的Session共享的詳細教程

SpringBoot中實現分散式的Session共享的詳細教程

在瀏覽器中,我們的8080和8081埠上訪問時,可以看到有一個共同的Session資訊:

SpringBoot中實現分散式的Session共享的詳細教程

可以看到在兩個不同的程序埠上,都分別訪問到了同一個session資訊,說明我們實現了分散式程序中session共享。可見在有了Spring Session後,實現session共享還是很簡單得到。

總結

到此這篇關於SpringBoot中實現分散式的Session共享的詳細教程的文章就介紹到這了,更多相關SpringBoot分散式Session共享內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!