色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

Springboot Session共享實(shí)現(xiàn)原理及代碼實(shí)例

瀏覽:26日期:2023-05-01 18:57:31

在傳統(tǒng)的單服務(wù)架構(gòu)中,一般來說,只有一個服務(wù)器,那么不存在 Session

共享問題,但是在分布式/集群項(xiàng)目中,Session 共享則是一個必須面對的問題,先看一個簡單的架構(gòu)圖:

Springboot Session共享實(shí)現(xiàn)原理及代碼實(shí)例

在這樣的架構(gòu)中,會出現(xiàn)一些單服務(wù)中不存在的問題,例如客戶端發(fā)起一個請求,這個請求到達(dá) Nginx 上之后,被Nginx 轉(zhuǎn)發(fā)到 Tomcat A 上,然后在 Tomcat A 上往 session 中保存了一份數(shù)據(jù),下次又來一個請求,這個請求被轉(zhuǎn)發(fā)到 TomcatB 上,此時再去 Session中獲取數(shù)據(jù),發(fā)現(xiàn)沒有之前的數(shù)據(jù)。對于這一類問題的解決,思路很簡單,就是將各個服務(wù)之間需要共享的數(shù)據(jù),保存到一個公共的地方(主流方案就是 Redis):

Springboot Session共享實(shí)現(xiàn)原理及代碼實(shí)例

1 實(shí)戰(zhàn)

1.1 創(chuàng)建工程

首先 創(chuàng)建一個 Spring Boot 工程,引入 Web、Spring Session 以及 Redis:

Springboot Session共享實(shí)現(xiàn)原理及代碼實(shí)例

創(chuàng)建成功之后,pom.xml 文件如下:

<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</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></dependencies>

注意:

這里我使用的 Spring Boot 版本是 2.1.4 ,如果使用當(dāng)前最新版 Spring Boot2.1.5的話,除了上面這些依賴之外,需要額外添加 Spring Security 依賴(其他操作不受影響,僅僅只是多了一個依賴,當(dāng)然也多了 Spring Security 的一些默認(rèn)認(rèn)證流程)。

1.2 配置 Redis

spring.redis.host=192.168.66.128spring.redis.port=6379spring.redis.password=123spring.redis.database=0

1.3 使用

配置完成后 ,就可以使用 Spring Session 了,其實(shí)就是使用普通的 HttpSession ,其他的 Session 同步到 Redis 等操作,框架已經(jīng)自動幫你完成了:

@RestControllerpublic class HelloController { @Value('${server.port}') Integer port; @GetMapping('/set') public String set(HttpSession session) { session.setAttribute('user', 'javaboy'); return String.valueOf(port); } @GetMapping('/get') public String get(HttpSession session) { return session.getAttribute('user') + ':' + port; }}

考慮到一會 Spring Boot 將以集群的方式啟動 ,為了獲取每一個請求到底是哪一個 Spring Boot 提供的服務(wù),需要在每次請求時返回當(dāng)前服務(wù)的端口號,因此這里我注入了 server.port 。

接下來 ,項(xiàng)目打包:

Springboot Session共享實(shí)現(xiàn)原理及代碼實(shí)例

打包之后,啟動項(xiàng)目的兩個實(shí)例:

java -jar sessionshare-0.0.1-SNAPSHOT.jar --server.port=8080java -jar sessionshare-0.0.1-SNAPSHOT.jar --server.port=8081

然后先訪問 localhost:8080/set 向 8080 這個服務(wù)的 Session 中保存一個變量,訪問完成后,數(shù)據(jù)就已經(jīng)自動同步到 Redis 中 了 :

Springboot Session共享實(shí)現(xiàn)原理及代碼實(shí)例

然后,再調(diào)用 localhost:8081/get 接口,就可以獲取到 8080 服務(wù)的 session 中的數(shù)據(jù):

Springboot Session共享實(shí)現(xiàn)原理及代碼實(shí)例

此時關(guān)于 session 共享的配置就已經(jīng)全部完成了,session 共享的效果我們已經(jīng)看到了,但是每次訪問都是我自己手動切換服務(wù)實(shí)例,因此,接下來我們來引入 Nginx ,實(shí)現(xiàn)服務(wù)實(shí)例自動切換。

1.4 引入 Nginx

很簡單,進(jìn)入 Nginx 的安裝目錄的 conf 目錄下(默認(rèn)是在 /usr/local/nginx/conf),編輯 nginx.conf 文件:

Springboot Session共享實(shí)現(xiàn)原理及代碼實(shí)例

在這段配置中:

upstream 表示配置上游服務(wù)器 javaboy.org 表示服務(wù)器集群的名字,這個可以隨意取名字 upstream 里邊配置的是一個個的單獨(dú)服務(wù) weight 表示服務(wù)的權(quán)重,意味者將有多少比例的請求從 Nginx 上轉(zhuǎn)發(fā)到該服務(wù)上 location 中的 proxy_pass 表示請求轉(zhuǎn)發(fā)的地址,/ 表示攔截到所有的請求,轉(zhuǎn)發(fā)轉(zhuǎn)發(fā)到剛剛配置好的服務(wù)集群中 proxy_redirect 表示設(shè)置當(dāng)發(fā)生重定向請求時,nginx 自動修正響應(yīng)頭數(shù)據(jù)(默認(rèn)是 Tomcat 返回重定向,此時重定向的地址是 Tomcat 的地址,我們需要將之修改使之成為 Nginx 的地址)。

配置完成后,將本地的 Spring Boot 打包好的 jar 上傳到 Linux ,然后在 Linux 上分別啟動兩個 Spring Boot 實(shí)例:

nohup java -jar sessionshare-0.0.1-SNAPSHOT.jar --server.port=8080 & nohup java -jar sessionshare-0.0.1-SNAPSHOT.jar --server.port=8081 &

其中

nohup 表示當(dāng)終端關(guān)閉時,Spring Boot 不要停止運(yùn)行 & 表示讓 Spring Boot 在后臺啟動

配置完成后,重啟 Nginx:

/usr/local/nginx/sbin/nginx -s reload

Nginx 啟動成功后,我們首先手動清除 Redis 上的數(shù)據(jù),然后訪問 192.168.66.128/set 表示向 session 中保存數(shù)據(jù),這個請求首先會到達(dá) Nginx 上,再由 Nginx 轉(zhuǎn)發(fā)給某一個 Spring Boot 實(shí)例:

Springboot Session共享實(shí)現(xiàn)原理及代碼實(shí)例

如上,表示端口為 8081 的 Spring Boot 處理了這個 /set 請求,再訪問 /get 請求:

Springboot Session共享實(shí)現(xiàn)原理及代碼實(shí)例

可以看到,/get 請求是被端口為 8080 的服務(wù)所處理的。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 免费在线观看黄色毛片 | 大焦伊人 | 日韩特级毛片 | 亚洲国产精品久久久久久 | 欧美一级毛片特黄黄 | 牛人盗摄一区二区三区视频 | 久久免费视频播放 | 国产午夜精品久久久久免费视 | 91久久青青草原线免费 | 成人毛片网站 | a级国产乱理伦片在线观看99 | 亚洲午夜综合网 | 精品在线观看国产 | 久爱综合| 中国内地毛片免费高清 | 欧洲性大片xxxxx久久久 | 日韩激情中文字幕一区二区 | 欧美毛片a级毛片免费观 | 国产福利不卡一区二区三区 | 99手机在线视频 | 免费看真人a一级毛片 | 国产高清在线精品一区二区 | 亚洲国语在线视频手机在线 | 国产精品亚洲欧美日韩久久 | 久久这里只有精品免费视频 | 99je全部都是精品视频在线 | 伊人久爱 | 日韩一级大片 | 日本韩经典三级在线播放 | 国产精品久久一区二区三区 | 欧美一级看片 | 欧美日韩在线观看一区 | 全部aⅴ极品视觉盛宴精品 全部免费a级毛片 | 免费在线精品视频 | 亚洲美女高清aⅴ视频免费 亚洲美女黄色片 | 午夜影院a级片 | 99re热视频| 日韩欧美亚洲中字幕在线播放 | 日本免费人做人一区在线观看 | 国内国外精品一区二区 | 国产视频手机在线 |