SpringBoot中使用Session共享實(shí)現(xiàn)分布式部署的示例代碼
前言:我們知道,在單體項(xiàng)目中,我們將用戶信息存在 session 中,那么在該 session 過(guò)期之前,我們都可以從 session 中獲取到用戶信息,通過(guò)登錄攔截,進(jìn)行操作
但是分布式部署的時(shí)候,我們請(qǐng)求的服務(wù)器可能不是同一臺(tái)服務(wù)器,那么我們就必須要面對(duì) session 共享的問(wèn)題,下面介紹的是在 SpringBoot 實(shí)現(xiàn) session 共享的方式
一、創(chuàng)建項(xiàng)目
創(chuàng)建 SpringBoot 項(xiàng)目,選擇 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 實(shí)現(xiàn) session 共享,所以我們需要在配置文件中配置 redis 的信息
server: port: 8080spring: redis: host: 127.0.0.1 port: 6379 database: 0 password:
我們配置了該項(xiàng)目的端口,以及 redis 的連接信息
三、寫(xiě)接口
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 { /** * 獲取項(xiàng)目端口 */ @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; }}
我們寫(xiě)了一個(gè) set,一個(gè) get 方法,將信息存放在 session 中,從 session 中取出信息
四、打包測(cè)試

啟動(dòng)項(xiàng)目,分別啟動(dòng)在兩個(gè)端口:
java -jar .session-0.0.1-SNAPSHOT.jar --server.port=8080java -jar .session-0.0.1-SNAPSHOT.jar --server.port=8081
分別啟動(dòng)在 8080,8081端口
訪問(wèn):http://localhost:8080/set

我們從 8080 端口,將信息保存在 session 中
我們?cè)L問(wèn):http://localhost:8081/get

我們?cè)?8081 端口的項(xiàng)目中從 session 中取出了內(nèi)容:hello world~~~
由此證明,我們的 session 共享已經(jīng)成功
五、分布式部署
下面我們借助 nginx 代理轉(zhuǎn)發(fā)訪問(wèn)這兩個(gè)項(xiàng)目
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;}
攔截本地的所有請(qǐng)求,默認(rèn)端口為 80
2、啟動(dòng) nginx
nginx -s reload
3、訪問(wèn)測(cè)試
我們先刪除 redis 里面剛剛測(cè)試保存的信息

然后我們?cè)L問(wèn):
http://localhost/set

這里我們可以看出,由 8080 端口的服務(wù)器完成了 set 請(qǐng)求,多次訪問(wèn),nginx 將會(huì)根據(jù)什么配置的權(quán)重參數(shù)分配服務(wù)器來(lái)完成操作
下面我們?cè)L問(wèn):
http://localhost/get

可以看出,由 8081 端口的服務(wù)器完成了 get 請(qǐng)求,并成功取到了存在 session 中的數(shù)據(jù),實(shí)現(xiàn)了 session 共享
六、總結(jié)
1、以前我們?cè)?SSM 架構(gòu)的項(xiàng)目中實(shí)現(xiàn) session 共享,需要配置三個(gè)地方 ,一個(gè)是 web.xml 配置代理過(guò)濾器,然后在 Spring 容器中配置 Redis,最后再配置 Spring Session,相比 SpringBoot,稍有復(fù)雜2、我們?cè)?SpringBoot 中實(shí)現(xiàn) session 共享還是非常簡(jiǎn)單的,只需要引入依賴,簡(jiǎn)單配置即可實(shí)現(xiàn)3、實(shí)現(xiàn) session 共享,幫助我們將項(xiàng)目分布式部署,提升服務(wù)性能有很大的意義
到此這篇關(guān)于SpringBoot中使用Session共享實(shí)現(xiàn)分布式部署的示例代碼的文章就介紹到這了,更多相關(guān)SpringBoot Session分布式部署內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. CentOS郵箱服務(wù)器搭建系列——SMTP服務(wù)器的構(gòu)建( Postfix )2. asp文件用什么軟件編輯3. PHP基礎(chǔ)之生成器4——比較生成器和迭代器對(duì)象4. ASP新手必備的基礎(chǔ)知識(shí)5. Docker 啟動(dòng)Redis 并設(shè)置密碼的操作6. vue+element開(kāi)發(fā)一個(gè)谷歌插件的全過(guò)程7. Vue axios獲取token臨時(shí)令牌封裝案例8. JS中6個(gè)對(duì)象數(shù)組去重的方法9. 利用CSS制作3D動(dòng)畫(huà)10. Spring如何替換掉默認(rèn)common-logging.jar

網(wǎng)公網(wǎng)安備