SpringBoot中使用Session共享實(shí)現(xiàn)分布式部署的示例代碼
前言:我們知道,在單體項(xiàng)目中,我們將用戶信息存在 session 中,那么在該 session 過期之前,我們都可以從 session 中獲取到用戶信息,通過登錄攔截,進(jìn)行操作
但是分布式部署的時(shí)候,我們請求的服務(wù)器可能不是同一臺(tái)服務(wù)器,那么我們就必須要面對(duì) session 共享的問題,下面介紹的是在 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 的連接信息
三、寫接口
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; }}
我們寫了一個(gè) set,一個(gè) get 方法,將信息存放在 session 中,從 session 中取出信息
四、打包測試
啟動(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端口
訪問:http://localhost:8080/set
我們從 8080 端口,將信息保存在 session 中
我們訪問:http://localhost:8081/get
我們在 8081 端口的項(xiàng)目中從 session 中取出了內(nèi)容:hello world~~~
由此證明,我們的 session 共享已經(jīng)成功
五、分布式部署
下面我們借助 nginx 代理轉(zhuǎn)發(fā)訪問這兩個(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;}
攔截本地的所有請求,默認(rèn)端口為 80
2、啟動(dòng) nginx
nginx -s reload
3、訪問測試
我們先刪除 redis 里面剛剛測試保存的信息
然后我們訪問:
http://localhost/set
這里我們可以看出,由 8080 端口的服務(wù)器完成了 set 請求,多次訪問,nginx 將會(huì)根據(jù)什么配置的權(quán)重參數(shù)分配服務(wù)器來完成操作
下面我們訪問:
http://localhost/get
可以看出,由 8081 端口的服務(wù)器完成了 get 請求,并成功取到了存在 session 中的數(shù)據(jù),實(shí)現(xiàn)了 session 共享
六、總結(jié)
1、以前我們在 SSM 架構(gòu)的項(xiàng)目中實(shí)現(xiàn) session 共享,需要配置三個(gè)地方 ,一個(gè)是 web.xml 配置代理過濾器,然后在 Spring 容器中配置 Redis,最后再配置 Spring Session,相比 SpringBoot,稍有復(fù)雜2、我們在 SpringBoot 中實(shí)現(xiàn) session 共享還是非常簡單的,只需要引入依賴,簡單配置即可實(shí)現(xiàn)3、實(shí)現(xiàn) session 共享,幫助我們將項(xiàng)目分布式部署,提升服務(wù)性能有很大的意義
到此這篇關(guān)于SpringBoot中使用Session共享實(shí)現(xiàn)分布式部署的示例代碼的文章就介紹到這了,更多相關(guān)SpringBoot Session分布式部署內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. ASP 連接Access數(shù)據(jù)庫的登陸系統(tǒng)2. phpstudy apache開啟ssi使用詳解3. 深入理解Android熱修復(fù)技術(shù)原理之代碼熱修復(fù)技術(shù)4. asp知識(shí)整理筆記4(問答模式)5. ASP腳本組件實(shí)現(xiàn)服務(wù)器重啟6. Java雙向鏈表按照順序添加節(jié)點(diǎn)的方法實(shí)例7. Android實(shí)現(xiàn)簡單用戶注冊案例8. Python實(shí)現(xiàn)播放和錄制聲音的功能9. python 爬取豆瓣網(wǎng)頁的示例10. AJAX的跨域問題解決方案
