溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何使用SpringBoot2.x整合Spring-Session實(shí)現(xiàn)Session共享功能

發(fā)布時(shí)間:2021-09-28 14:04:00 來(lái)源:億速云 閱讀:116 作者:小新 欄目:編程語(yǔ)言

這篇文章主要介紹了如何使用SpringBoot2.x整合Spring-Session實(shí)現(xiàn)Session共享功能,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

1.前言

發(fā)展至今,已經(jīng)很少還存在單服務(wù)的應(yīng)用架構(gòu),不說(shuō)都使用分布式架構(gòu)部署, 至少也是多點(diǎn)高可用服務(wù)。在多個(gè)服務(wù)器的情況下,Seession共享就是必須面對(duì)的問(wèn)題了。

解決Session共享問(wèn)題,大多數(shù)人的思路都是比較清晰的, 將需要共享的數(shù)據(jù)存在某個(gè)公共的服務(wù)中,如緩存。很多人都采用的Redis,手動(dòng)將Session存在Redis,需要使用時(shí),再?gòu)腞edsi中讀取數(shù)據(jù)。毫無(wú)疑問(wèn),這種方案是可行的,只是在手動(dòng)操作的工作量確實(shí)不少。

LZ在這里采用的Spring-Session來(lái)實(shí)現(xiàn)。它使用代理過(guò)濾器,將Session操作攔截,自動(dòng)將數(shù)據(jù)同步到Redis中,以及自動(dòng)從Redis讀取數(shù)據(jù)。從此,操作分布式的Session就像操作單服務(wù)的Session一樣,可以為所欲為了。

2.實(shí)踐

2.1 創(chuàng)建工程

使用idea創(chuàng)建SpringBoot工程, 添加組件Web、Spring Session和Redis。 我這里idea是2019版本,SpringBoot是2.1.6。

pom.xml文件

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

2.2 配置Redis

spring: redis:   port: 6379   password: xofcO46Fy   host: 10.17.153.104server: port: 9090

2.3 測(cè)試

代碼實(shí)現(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 <br> * 〈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ā)布到服務(wù)器服務(wù)器,過(guò)程略。

分別使用9090 9091端口啟動(dòng)項(xiàng)目。

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

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

先訪問(wèn)http://10.17.158.136:9090/session/set,在9090這個(gè)服務(wù)的session保存用戶變量;

然后再訪問(wèn)http://10.17.158.136:9091/session/get,從session中獲取得到用戶信息。

從上面樣例,可以看出session已經(jīng)實(shí)現(xiàn)了共享,只是測(cè)試過(guò)程是需要手動(dòng)切換服務(wù)。為了更好地模式真實(shí)項(xiàng)目環(huán)境,為此,我們配置Nginx,來(lái)進(jìn)行測(cè)試。

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;    }

在這里我們只需要配置簡(jiǎn)單的負(fù)載均衡,端口是9000。所有l(wèi)ocalhost:9000都會(huì)按一定策略(這里是按權(quán)重分發(fā),配置weight=1一樣,隨機(jī)分發(fā)的;nginx默認(rèn)是輪詢策略)分發(fā)到上游服務(wù)upstream配置的服務(wù)上。

配置完成后,啟動(dòng)Nginx;

/apps/test/software/nginx/nginx-1.6.2/sbin/nginx

首先訪問(wèn)http://10.17.158.136:9000/session/set,向seesion中保存數(shù)據(jù),從下圖中可知9090端口的服務(wù)處理了該請(qǐng)求。

然后在訪問(wèn)/get請(qǐng)求,是從9091端口的服務(wù)獲取得到的用戶信息,至此,測(cè)試完成。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“如何使用SpringBoot2.x整合Spring-Session實(shí)現(xiàn)Session共享功能”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI