激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Springboot Session共享實現原理及代碼實例

Springboot Session共享實現原理及代碼實例

2020-08-17 12:22柒丶月 Java教程

這篇文章主要介紹了Springboot Session共享實現原理及代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

在傳統的單服務架構中,一般來說,只有一個服務器,那么不存在 Session

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

Springboot Session共享實現原理及代碼實例

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

Springboot Session共享實現原理及代碼實例

1 實戰

1.1 創建工程

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

Springboot Session共享實現原理及代碼實例

創建成功之后,pom.xml 文件如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<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 ,如果使用當前最新版 Spring Boot2.1.5的話,除了上面這些依賴之外,需要額外添加 Spring Security 依賴(其他操作不受影響,僅僅只是多了一個依賴,當然也多了 Spring Security 的一些默認認證流程)。

1.2 配置 Redis

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

1.3 使用

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
@RestController
public 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 提供的服務,需要在每次請求時返回當前服務的端口號,因此這里我注入了 server.port 。

接下來 ,項目打包:

Springboot Session共享實現原理及代碼實例

打包之后,啟動項目的兩個實例:

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

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

Springboot Session共享實現原理及代碼實例

然后,再調用 localhost:8081/get 接口,就可以獲取到 8080 服務的 session 中的數據:

Springboot Session共享實現原理及代碼實例

此時關于 session 共享的配置就已經全部完成了,session 共享的效果我們已經看到了,但是每次訪問都是我自己手動切換服務實例,因此,接下來我們來引入 Nginx ,實現服務實例自動切換。

1.4 引入 Nginx

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

Springboot Session共享實現原理及代碼實例

在這段配置中:

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

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

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 表示當終端關閉時,Spring Boot 不要停止運行
  • & 表示讓 Spring Boot 在后臺啟動

配置完成后,重啟 Nginx:

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

Nginx 啟動成功后,我們首先手動清除 Redis 上的數據,然后訪問 192.168.66.128/set 表示向 session 中保存數據,這個請求首先會到達 Nginx 上,再由 Nginx 轉發給某一個 Spring Boot 實例:

Springboot Session共享實現原理及代碼實例

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

Springboot Session共享實現原理及代碼實例

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://www.cnblogs.com/qiuwenli/p/13442916.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: av手机在线免费播放 | 久久久精品视频在线观看 | 国产成年人网站 | 91久久极品少妇韩国 | 性欧美日本 | 极色品影院 | 爱爱视频天天干 | 成人免费网站在线观看 | 新久草在线视频 | 99视频网址 | 日本网站一区二区三区 | 中文字幕 亚洲一区 | 老师你怎么会在这第2季出现 | 羞羞电影在线观看www | 欧美成人免费tv在线播放 | 成人aaaaa片毛片按摩 | 免费观看一级欧美大 | 欧美一区二区三区免费电影 | 日韩一级片黄色 | 亚洲精品久久久久久久久久久 | 欧洲成人一区 | 日本人乱人乱亲乱色视频观看 | 成人免费区 | 久久久久女人精品毛片 | 国产精品啪一品二区三区粉嫩 | 免费观看一区二区三区视频 | 中国女警察一级毛片视频 | 欧美日韩电影在线 | 玩偶姐姐 在线观看 | 国产欧美精品综合一区 | 亚洲国产精品久久久久婷婷老年 | 日本黄色a视频 | 2021狠狠操 | 久久久久久久久久91 | 国产亚洲精品久久久久5区 99精品视频在线 | 999av视频| 欧美巨乳在线观看 | 黄色一级毛片免费看 | 欧美成人免费电影 | jizzjizz中国少妇中文 | 91久久国产露脸精品国产 |