這篇文章主要介紹了如何使用SpringBoot2.x整合Spring-Session實現(xiàn)Session共享功能,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
成都創(chuàng)新互聯(lián)長期為成百上千客戶提供的網站建設服務,團隊從業(yè)經驗10年,關注不同地域、不同群體,并針對不同對象提供差異化的產品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網生態(tài)環(huán)境。為從化企業(yè)提供專業(yè)的網站設計、網站制作,從化網站改版等技術服務。擁有十余年豐富建站經驗和眾多成功案例,為您定制開發(fā)。
1.前言
發(fā)展至今,已經很少還存在單服務的應用架構,不說都使用分布式架構部署, 至少也是多點高可用服務。在多個服務器的情況下,Seession共享就是必須面對的問題了。
解決Session共享問題,大多數(shù)人的思路都是比較清晰的, 將需要共享的數(shù)據(jù)存在某個公共的服務中,如緩存。很多人都采用的redis,手動將Session存在Redis,需要使用時,再從Redsi中讀取數(shù)據(jù)。毫無疑問,這種方案是可行的,只是在手動操作的工作量確實不少。
LZ在這里采用的Spring-Session來實現(xiàn)。它使用代理過濾器,將Session操作攔截,自動將數(shù)據(jù)同步到Redis中,以及自動從Redis讀取數(shù)據(jù)。從此,操作分布式的Session就像操作單服務的Session一樣,可以為所欲為了。
2.實踐
2.1 創(chuàng)建工程
使用idea創(chuàng)建SpringBoot工程, 添加組件Web、Spring Session和Redis。 我這里idea是2019版本,SpringBoot是2.1.6。
pom.xml文件
2.2 配置Redis
spring: redis: port: 6379 password: xofcO46Fy host: 10.17.153.104server: port: 9090
2.3 測試
代碼實現(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
* 〈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 "用戶:"+session.getAttribute("user")+",端口:"+port; }}
maven package打包發(fā)布到服務器服務器,過程略。
分別使用9090 9091端口啟動項目。
nohup java -jar sessionshare-0.0.1-SNAPSHOT.jar --server.port=9090 &
nohup java -jar sessionshare-0.0.1-SNAPSHOT.jar --server.port=9091 &
先訪問http://10.17.158.136:9090/session/set,在9090這個服務的session保存用戶變量;
然后再訪問http://10.17.158.136:9091/session/get,從session中獲取得到用戶信息。
從上面樣例,可以看出session已經實現(xiàn)了共享,只是測試過程是需要手動切換服務。為了更好地模式真實項目環(huán)境,為此,我們配置Nginx,來進行測試。
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; }
在這里我們只需要配置簡單的負載均衡,端口是9000。所有l(wèi)ocalhost:9000都會按一定策略(這里是按權重分發(fā),配置weight=1一樣,隨機分發(fā)的;nginx默認是輪詢策略)分發(fā)到上游服務upstream配置的服務上。
配置完成后,啟動Nginx;
/apps/test/software/nginx/nginx-1.6.2/sbin/nginx
首先訪問http://10.17.158.136:9000/session/set,向seesion中保存數(shù)據(jù),從下圖中可知9090端口的服務處理了該請求。
然后在訪問/get請求,是從9091端口的服務獲取得到的用戶信息,至此,測試完成。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“如何使用SpringBoot2.x整合Spring-Session實現(xiàn)Session共享功能”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關知識等著你來學習!