溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot2.x 整合Spring-Session實現Session共享功能

發布時間:2020-09-23 19:19:54 來源:腳本之家 閱讀:207 作者:指尖逆蒼穹 欄目:編程語言

1.前言

發展至今,已經很少還存在單服務的應用架構,不說都使用分布式架構部署, 至少也是多點高可用服務。在多個服務器的情況下,Seession共享就是必須面對的問題了。

解決Session共享問題,大多數人的思路都是比較清晰的, 將需要共享的數據存在某個公共的服務中,如緩存。很多人都采用的Redis,手動將Session存在Redis,需要使用時,再從Redsi中讀取數據。毫無疑問,這種方案是可行的,只是在手動操作的工作量確實不少。

LZ在這里采用的Spring-Session來實現。它使用代理過濾器,將Session操作攔截,自動將數據同步到Redis中,以及自動從Redis讀取數據。從此,操作分布式的Session就像操作單服務的Session一樣,可以為所欲為了。

2.實踐

2.1 創建工程

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

SpringBoot2.x 整合Spring-Session實現Session共享功能

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.104
server:
 port: 9090

2.3 測試

代碼實現

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打包發布到服務器服務器,過程略。

分別使用9090 9091端口啟動項目。

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

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

先訪問http://10.17.158.136:9090/session/set,在9090這個服務的session保存用戶變量;

SpringBoot2.x 整合Spring-Session實現Session共享功能

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

SpringBoot2.x 整合Spring-Session實現Session共享功能

從上面樣例,可以看出session已經實現了共享,只是測試過程是需要手動切換服務。為了更好地模式真實項目環境,為此,我們配置Nginx,來進行測試。

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

在這里我們只需要配置簡單的負載均衡,端口是9000。所有localhost:9000都會按一定策略(這里是按權重分發,配置weight=1一樣,隨機分發的;nginx默認是輪詢策略)分發到上游服務upstream配置的服務上。

配置完成后,啟動Nginx;

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

首先訪問http://10.17.158.136:9000/session/set,向seesion中保存數據,從下圖中可知9090端口的服務處理了該請求。


SpringBoot2.x 整合Spring-Session實現Session共享功能

然后在訪問/get請求,是從9091端口的服務獲取得到的用戶信息,至此,測試完成。

SpringBoot2.x 整合Spring-Session實現Session共享功能

3.總結

本文主要是Spring Session的簡單使用,從上面可以看出,除了引入了Spring Session的jar, 其他方面,不管是代碼還是配置,都與之沒有什么關聯,就相當于在操作最常用的HttpSession,在實際項目中用起來也是相當方便。

樣例已上傳github,地址:https://github.com/lanxuan826/sample-library/tree/master/sessionshare,有興趣可下載測試。

以上所述是小編給大家介紹的SpringBoot2.x 整合Spring-Session實現Session共享,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女