SpringBoot2.x 整合Spring-Session實(shí)現(xiàn)Session共享功能
1.前言
發(fā)展至今,已經(jīng)很少還存在單服務(wù)的應(yīng)用架構(gòu),不說(shuō)都使用分布式架構(gòu)部署, 至少也是多點(diǎn)高可用服務(wù)。在多個(gè)服務(wù)器的情況下,Seession共享就是必須面對(duì)的問(wèn)題了。
解決Session共享問(wèn)題,大多數(shù)人的思路都是比較清晰的, 將需要共享的數(shù)據(jù)存在某個(gè)公共的服務(wù)中,如緩存。很多人都采用的Redis,手動(dòng)將Session存在Redis,需要使用時(shí),再?gòu)腞edsi中讀取數(shù)據(jù)。毫無(wú)疑問(wèn),這種方案是可行的,只是在手動(dòng)操作的工作量確實(shí)不少。
LZ在這里采用的Spring-Session來(lái)實(shí)現(xiàn)。它使用代理過(guò)濾器,將Session操作攔截,自動(dòng)將數(shù)據(jù)同步到Redis中,以及自動(dòng)從Redis讀取數(shù)據(jù)。從此,操作分布式的Session就像操作單服務(wù)的Session一樣,可以為所欲為了。
2.實(shí)踐
2.1 創(chuàng)建工程
使用idea創(chuàng)建SpringBoot工程, 添加組件Web、Spring Session和Redis。 我這里idea是2019版本,SpringBoot是2.1.6。
pom.xml文件
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis-reactive</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-data-redis</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies>
2.2 配置Redis
spring: redis: port: 6379 password: xofcO46Fy host: 10.17.153.104 server: port: 9090
2.3 測(cè)試
代碼實(shí)現(xiàn)
package com.xiaoqiang.sessionshare.web; import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import javax.servlet.http.HttpSession; /** * SessionShareController <br> * 〈session共享控制器〉 * * @author XiaoQiang * @create 2019-7-6 * @since 1.0.0 */ @RestController @RequestMapping(value = "/session") public class SessionShareController { @Value("${server.port}") Integer port; @GetMapping(value = "/set") public String set(HttpSession session){ session.setAttribute("user","wangwq8"); return String.valueOf(port); } @GetMapping(value = "get") public String get(HttpSession session){ return "用戶(hù):"+session.getAttribute("user")+",端口:"+port; } }
maven package打包發(fā)布到服務(wù)器服務(wù)器,過(guò)程略。
分別使用9090 9091端口啟動(dòng)項(xiàng)目。
nohup java -jar sessionshare-0.0.1-SNAPSHOT.jar --server.port=9090 &
nohup java -jar sessionshare-0.0.1-SNAPSHOT.jar --server.port=9091 &
先訪問(wèn)http://10.17.158.136:9090/session/set,在9090這個(gè)服務(wù)的session保存用戶(hù)變量;
然后再訪問(wèn)http://10.17.158.136:9091/session/get,從session中獲取得到用戶(hù)信息。
從上面樣例,可以看出session已經(jīng)實(shí)現(xiàn)了共享,只是測(cè)試過(guò)程是需要手動(dòng)切換服務(wù)。為了更好地模式真實(shí)項(xiàng)目環(huán)境,為此,我們配置Nginx,來(lái)進(jìn)行測(cè)試。
2.4 配置Nginx
在Nginx安裝目錄conf下,編輯nginx.conf,
upstream tomcatServer { server 10.17.158.136:9092 weight=1; server 10.17.158.136:9091 weight=2; } server { listen 9000; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; location / { proxy_pass http://tomcatServer; proxy_redirect default; #root html; #index index.html index.htm; } #error_page 404 /404.html; # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; location = /50x.html { root html; }
在這里我們只需要配置簡(jiǎn)單的負(fù)載均衡,端口是9000。所有l(wèi)ocalhost:9000都會(huì)按一定策略(這里是按權(quán)重分發(fā),配置weight=1一樣,隨機(jī)分發(fā)的;nginx默認(rèn)是輪詢(xún)策略)分發(fā)到上游服務(wù)upstream配置的服務(wù)上。
配置完成后,啟動(dòng)Nginx;
/apps/test/software/nginx/nginx-1.6.2/sbin/nginx
首先訪問(wèn)http://10.17.158.136:9000/session/set,向seesion中保存數(shù)據(jù),從下圖中可知9090端口的服務(wù)處理了該請(qǐng)求。
然后在訪問(wèn)/get請(qǐng)求,是從9091端口的服務(wù)獲取得到的用戶(hù)信息,至此,測(cè)試完成。
3.總結(jié)
本文主要是Spring Session的簡(jiǎn)單使用,從上面可以看出,除了引入了Spring Session的jar, 其他方面,不管是代碼還是配置,都與之沒(méi)有什么關(guān)聯(lián),就相當(dāng)于在操作最常用的HttpSession,在實(shí)際項(xiàng)目中用起來(lái)也是相當(dāng)方便。
樣例已上傳github,地址:https://github.com/lanxuan826/sample-library/tree/master/sessionshare,有興趣可下載測(cè)試。
以上所述是小編給大家介紹的SpringBoot2.x 整合Spring-Session實(shí)現(xiàn)Session共享,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
- SpringBoot3整合MyBatis出現(xiàn)異常:Property?'sqlSessionFactory'or?'sqlSessionTemplate'?are?required
- SpringBoot整合ES-Elasticsearch的實(shí)例
- springboot restTemplate連接池整合方式
- SpringBoot整合Mybatis,解決TypeAliases配置失敗的問(wèn)題
- Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動(dòng)刷新配置的教程
- es(elasticsearch)整合SpringCloud(SpringBoot)搭建教程詳解
- SpringBoot 整合Jest實(shí)例代碼講解
- SpringBoot整合ES解析搜索返回字段問(wèn)題
相關(guān)文章
Spring?Boot?打包成Jar包運(yùn)行原理分析
這篇文章主要為大家介紹了Spring?Boot?打包成Jar包運(yùn)行的原理分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09Spring整合WebSocket應(yīng)用示例(上)
以下教程是小編在參與開(kāi)發(fā)公司的一個(gè)crm系統(tǒng),整理些相關(guān)資料,在該系統(tǒng)中有很多消息推送功能,在其中用到了websocket技術(shù)。下面小編整理分享到腳本之家平臺(tái)供大家參考2016-04-04Java中的final關(guān)鍵字和抽象類(lèi)詳解
這篇文章主要介紹了Java中的final關(guān)鍵字和抽象類(lèi)詳解,當(dāng)不希望 類(lèi)被繼承時(shí),可以用final修飾比如不希望子類(lèi)重寫(xiě)父類(lèi)時(shí),當(dāng)不希望某個(gè)局部變量被修改時(shí),對(duì)參數(shù)進(jìn)行修飾,需要的朋友可以參考下2023-07-07Swagger2配置Security授權(quán)認(rèn)證全過(guò)程
這篇文章主要介紹了Swagger2配置Security授權(quán)認(rèn)證全過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03Mybatis詳解動(dòng)態(tài)SQL以及單表多表查詢(xún)的應(yīng)用
MyBatis的動(dòng)態(tài)SQL是基于OGNL表達(dá)式的,它可以幫助我們方便的在SQL語(yǔ)句中實(shí)現(xiàn)某些邏輯,下面這篇文章主要給大家介紹了關(guān)于Mybatis超級(jí)強(qiáng)大的動(dòng)態(tài)SQL語(yǔ)句的相關(guān)資料,需要的朋友可以參考下2022-06-06java操作gaussDB數(shù)據(jù)庫(kù)的實(shí)現(xiàn)示例
本文主要介紹了java操作gaussDB數(shù)據(jù)庫(kù)的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07org.slf4j.Logger中info()方法的使用詳解
這篇文章主要介紹了org.slf4j.Logger中info()方法的使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12Java Web制作登錄驗(yàn)證碼實(shí)現(xiàn)代碼解析
這篇文章主要介紹了Java Web制作登錄驗(yàn)證碼實(shí)現(xiàn)代碼解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09springboot集成nacos無(wú)法動(dòng)態(tài)獲取nacos配置的問(wèn)題
這篇文章主要介紹了springboot集成nacos無(wú)法動(dòng)態(tài)獲取nacos配置的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09