SpringBoot整合NoSql--(四)Session共用

来源:https://www.cnblogs.com/crazy-lc/archive/2020/02/23/12354503.html
-Advertisement-
Play Games

簡介: 正常情況下,HttpSession是通過Servlet 容器創建併進行管理的,創建成功之後都是保存在記憶體中。如果開發者需要對項目進行橫向擴展搭建集群,那麼可以利用一些硬體或者軟體工具來做負載均衡,此時,來自同一用戶的HTTP請求就有可能被分發到不同的實例上去,如何保證各個實例之間Sessio ...


簡介:

  正常情況下,HttpSession是通過Servlet 容器創建併進行管理的,創建成功之後都是保存在內
存中。如果開發者需要對項目進行橫向擴展搭建集群,那麼可以利用一些硬體或者軟體工具來做負
載均衡,此時,來自同一用戶的HTTP請求就有可能被分發到不同的實例上去,如何保證各個實例
之間Session的同步就成為一個必 須解決的問題。

  Spring Boot 提供了自動化的 Session共用配置,它結合Redis可以非常方便地解決這個問題。使用Redis 解決Session共用問題的原理非常簡單,就是把原本存儲在不同伺服器上的Session拿出來放在一個獨立的伺服器上。

  

  當一個請求到達Nginx伺服器後,首先進行請求分發,假設請求被real server 1處理了,real server 1在處理請求時,無論是存儲Session還是讀取Session,都去操作Session伺服器而不是操作自身記憶體中的Session,其他real server在處理請求時也是如此,這樣就可以實現Session共用了。

 

Demo:

  首先添加Redis和Session依賴,

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

application.properties

#使用0號庫,redis預設0-15,16個庫
spring.redis.database=0 
spring.redis.host=192.168.205.100
spring.redis.port=6379
spring.redis.password=123456
spring.redis.jedis.pool.max-active=8
spring.redis.jedis.pool.max-idle=8
spring.redis.jedis.pool.max-wait=-1ms
spring.redis.jedis.pool.min-idle=0

Controller:

  這裡提供了兩個方法,一個save介面用來向Session中存儲數據,還有一一個get 介面用來從Session中獲取數據。

  這裡註入了項目啟動的埠號server.port, 主要是為了區分到底是哪個伺服器提供的服務。另外,雖然還是操作的HttpSession,但是實際上HttpSession容器已經被透明替換,真正的Session此時存儲在Redis伺服器上。

@RestController
public class HelloController {

    @Value("${server.port}")
    String port;

    @PostMapping("/save")
    public String saveName(String name, HttpSession session) {
        session.setAttribute("name", name);
        return port;
    }

    @GetMapping("/get")
    public String getName(HttpSession session) {
        return port + ":"
                + session.getAttribute("name").toString();
    }

}

將項目打成jar上傳到centos,

 

 

 

 

 2.Nginx

下載--配置

 

 啟動:nginx預設80埠

[root@localhost sbin]# /usr/local/nginx/sbin/nginx

 

配置:

[root@localhost sbin]# vi /usr/local/nginx/conf/nginx.conf

 

 重啟nginx

[root@localhost sbin]# /usr/local/nginx/sbin/nginx -s reload

輸入:

http://192.168.205.100:80/save?name=eeeee

調用80埠,實際上使用8080

 

 http://192.168.205.100:80/get

調用80實際上是8081

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • jQuery 使用筆記 jQuery 基礎 1. jQuery 介紹 一個快速、輕量、豐富的 JavaScript 類庫 jQuery 官方網站:https://jquery.com jQuery 開發文檔:http://www.bejson.com/apidoc/jquery 2. jQuery ...
  • 程式設計七大原則 一、開閉原則 ​ 針對我們設計的功能模塊對擴展開放,對修改關閉:利用面向介面(抽象)編程(多態的特性),實現對功能需求擴展的同時,不允許更改原來的代碼。提高對象的可復用性、可維護性、靈活性。 ​ 抽象的說,用抽象思維構建我們想要創建的實體對象,用具體實現去擴展實體對象的細節實現。 ...
  • 這個假期有些長,長到忘記了要學習,要找工作,好吧,在我每天無休止的追著偶像劇時,我確實沒有負罪感,在聽了小祥大佬的分享後,我連睡午覺都被嚇醒。大佬跟我同一個班,在大廠工作,每天還抽時間學習,作業也沒落下,看看自己,再對比下別人,終於明白,我拿不到高薪原來是有原因的,話不多說,從昨天開始我進入了web ...
  • 阿裡雲的課程有邏輯回歸的內容的,學一下。 原理 分類變數:又稱定性變數或離散變數,觀察個體只能屬於互不相容的類別中的一組。一般用非數字表達。與之相對的是定量變數或連續變數,變數具有數值特征。 常見的有有序變數(年齡等級,收入等級等),名義變數(性別,天氣,職業等)。 自變數包含分類變數:名義變數通常 ...
  • MAC(媒介訪問控制層)位於各式物理層之上,控制數據的傳輸。它負責核心成幀操作以及與有線骨幹網路之間的交互。 802.11採用載波監聽多路訪問/衝突避免(CSMA/CA)機制來控制對傳輸媒介的訪問。 802.11與Ethernet之間的主要差異在於所使用的底層媒介不同,無線網路環境與傳統有線網路環境 ...
  • javaSE學習筆記(17) 鎖 Java提供了種類豐富的鎖,每種鎖因其特性的不同,在適當的場景下能夠展現出非常高的效率。本文旨在對鎖相關源碼(本文中的源碼來自JDK 8)、使用場景進行舉例,為讀者介紹主流鎖的知識點,以及不同的鎖的適用場景。 Java中往往是按照是否含有某一特性來定義鎖,我們通過特 ...
  • wget用途介紹 日常測試過程中,我們可以用wget命令,來下載一些資源文件。 wget是一個很好文件下載命令, Linux操作系統下,自帶wget命令。 Windows操作系統下,需要自己去下載並配置環境變數。 Windows版下載地址 "https://wget.en.softonic.com/ ...
  • mediainfo命令介紹 mediainfo.exe(Linux/iMac下是未帶尾碼的mediainfo), 是一款音視頻圖片文件的信息查詢工具, 常用於查看多媒體文件的視頻流信息,音頻流信息,字幕流信息等。 也可以用於查看圖片格式。 Windows版下載地址 "https://mediaare ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...