SpringBoot中使用Session共享實現(xiàn)分布式部署的示例代碼
前言:我們知道,在單體項目中,我們將用戶信息存在 session 中,那么在該 session 過期之前,我們都可以從 session 中獲取到用戶信息,通過登錄攔截,進(jìn)行操作
但是分布式部署的時候,我們請求的服務(wù)器可能不是同一臺服務(wù)器,那么我們就必須要面對 session 共享的問題,下面介紹的是在 SpringBoot 實現(xiàn) session 共享的方式
一、創(chuàng)建項目
創(chuàng)建 SpringBoot 項目,選擇 Maven 依賴
最終 pom.xml 文件如下:
<!-- redis的依賴 --><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId></dependency><!-- web的依賴 --><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId></dependency><!-- session共享的依賴 --><dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-data-redis</artifactId></dependency>
二、配置 Redis
我們需要借助 redis 實現(xiàn) session 共享,所以我們需要在配置文件中配置 redis 的信息
server: port: 8080spring: redis: host: 127.0.0.1 port: 6379 database: 0 password:
我們配置了該項目的端口,以及 redis 的連接信息
三、寫接口
package com.zyxx.session.controller;import org.springframework.beans.factory.annotation.Value;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpSession;@RestControllerpublic class DemoController { /** * 獲取項目端口 */ @Value('${server.port}') private String port; /** * 將信息存放在session中 */ @GetMapping('set') public String set(HttpSession session) { session.setAttribute('user', 'hello world~~~'); return port; } /** * 從session中獲取信息 */ @GetMapping('get') public String get(HttpSession session) { return session.getAttribute('user') + ' : ' + port; }}
我們寫了一個 set,一個 get 方法,將信息存放在 session 中,從 session 中取出信息
四、打包測試
啟動項目,分別啟動在兩個端口:
java -jar .session-0.0.1-SNAPSHOT.jar --server.port=8080java -jar .session-0.0.1-SNAPSHOT.jar --server.port=8081
分別啟動在 8080,8081端口
訪問:http://localhost:8080/set
我們從 8080 端口,將信息保存在 session 中
我們訪問:http://localhost:8081/get
我們在 8081 端口的項目中從 session 中取出了內(nèi)容:hello world~~~
由此證明,我們的 session 共享已經(jīng)成功
五、分布式部署
下面我們借助 nginx 代理轉(zhuǎn)發(fā)訪問這兩個項目
1、配置轉(zhuǎn)發(fā)
nginx 配置文件如下:
主要配置內(nèi)容:
upstream helloworld{server 127.0.0.1:8080 weight=1;server 127.0.0.1:8081 weight=2;}
這里配置轉(zhuǎn)發(fā)到 8080,8081 端口,并配置了權(quán)重
location / {proxy_pass http://helloworld; #root html; #index index.html index.htm;}
攔截本地的所有請求,默認(rèn)端口為 80
2、啟動 nginx
nginx -s reload
3、訪問測試
我們先刪除 redis 里面剛剛測試保存的信息
然后我們訪問:
http://localhost/set
這里我們可以看出,由 8080 端口的服務(wù)器完成了 set 請求,多次訪問,nginx 將會根據(jù)什么配置的權(quán)重參數(shù)分配服務(wù)器來完成操作
下面我們訪問:
http://localhost/get
可以看出,由 8081 端口的服務(wù)器完成了 get 請求,并成功取到了存在 session 中的數(shù)據(jù),實現(xiàn)了 session 共享
六、總結(jié)
1、以前我們在 SSM 架構(gòu)的項目中實現(xiàn) session 共享,需要配置三個地方 ,一個是 web.xml 配置代理過濾器,然后在 Spring 容器中配置 Redis,最后再配置 Spring Session,相比 SpringBoot,稍有復(fù)雜2、我們在 SpringBoot 中實現(xiàn) session 共享還是非常簡單的,只需要引入依賴,簡單配置即可實現(xiàn)3、實現(xiàn) session 共享,幫助我們將項目分布式部署,提升服務(wù)性能有很大的意義
到此這篇關(guān)于SpringBoot中使用Session共享實現(xiàn)分布式部署的示例代碼的文章就介紹到這了,更多相關(guān)SpringBoot Session分布式部署內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. Python 實現(xiàn)勞拉游戲的實例代碼(四連環(huán)、重力四子棋)2. Java GZip 基于內(nèi)存實現(xiàn)壓縮和解壓的方法3. SpringBoot+TestNG單元測試的實現(xiàn)4. jsp+servlet簡單實現(xiàn)上傳文件功能(保存目錄改進(jìn))5. PHP利用COM對象訪問SQLServer、Access6. 利用CSS制作3D動畫7. 一款功能強(qiáng)大的markdown編輯器tui.editor使用示例詳解8. 存儲于xml中需要的HTML轉(zhuǎn)義代碼9. JavaScript數(shù)據(jù)結(jié)構(gòu)之雙向鏈表10. .Net加密神器Eazfuscator.NET?2023.2?最新版使用教程
