首頁 運維 linux運維 Linux叢集/分散式環境下session處理方法介紹

Linux叢集/分散式環境下session處理方法介紹

Sep 08, 2017 am 09:55 AM
linux session 分散式

這篇文章主要為大家介紹了關於Linux叢集/分散式環境下session處理的五種策略,文中透過範例程式碼及圖片介紹的非常詳細,對大家的學習或工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。

前言

我們一般在搭建完叢集環境後,必須考慮的一個問題就是使用者存取產生的session如何處理。如果不做任何處理的話,使用者將出現頻繁登入的現象,例如叢集中存在A、B兩台伺服器,使用者在第一次造訪網站時,Nginx透過其負載平衡機制將使用者請求轉發到A伺服器,這時A伺服器就會為使用者建立一個Session。當使用者第二次發送請求時,Nginx將其負載平衡到B伺服器,而這時候B伺服器並不存在Session,所以就會將使用者踢到登入頁面。這將大大降低用戶體驗度,導致用戶的流失,這種情況是專案絕不應該出現的。

我們應該對產生的Session進行處理,透過黏性Session,Session複製或Session共享等方式保證使用者的體驗度。

以下我將說明5種Session處理策略,並分析其優劣性。話不多說了,來一起看看詳細的介紹吧。

第一種:黏性session

#原理:黏性Session是指將使用者鎖定在某一個伺服器上,例如上面說的例子,用戶第一次請求時,負載平衡器將用戶的請求轉發到了A伺服器上,如果負載平衡器設定了黏性Session的話,那麼用戶以後的每次請求都會轉發到A伺服器上,相當於把用戶和A伺服器黏到了一塊,這就是黏性Session機制。

優點:簡單,不需要對session做任何處理。

缺點:缺乏容錯性,如果目前存取的伺服器發生故障,使用者被轉移到第二個伺服器上時,他的session資訊都會失效。

適用場景:發生故障對客戶產生的影響較小;伺服器發生故障是低機率事件。

實作方式:以Nginx為例,在upstream模組設定ip_hash屬性即可實現黏性Session。


upstream mycluster{
 #这里添加的是上面启动好的两台Tomcat服务器
 ip_hash;#粘性Session
  server 192.168.22.229:8080 weight=1;
  server 192.168.22.230:8080 weight=1;
}
登入後複製

第二個:伺服器session複製

原理:任何一個伺服器上的session改變(增刪改),該節點會把這個session的所有內容序列化,然後廣播到所有其它節點,不管其他伺服器需不需要session,以此來保證Session同步。

優點:可容錯,各個伺服器間session能夠即時回應。

缺點:會對網路負荷造成一定壓力,如果session量大的話可能會造成網路阻塞,拖慢伺服器效能。

實作方式:

① 設定tomcat ,server.xml 開啟tomcat叢集功能

Linux叢集/分散式環境下session處理方法介紹
##Address:填寫本機ip即可,設定連接埠號,預防連接埠衝突。

② 在應用程式中增加資訊:通知應用程式目前處於叢集環境中,支援分散式


在web.xml中新增選項

第三種:session共享機制

#使用分散式快取方案例如memcached、redis,但是要求Memcached或Redis必須是集群。

使用Session共享也分兩種機制,兩種情況如下:

① 粘性session處理方式

原理:不同的tomcat指定訪問不同的主memcached。多個Memcached之間資訊是同步的,能主從備份和高可用。使用者存取時首先在tomcat中建立session,然後將session複製一份放到它對應的memcahed上。 memcache只起備份作用,讀寫都在tomcat上。當某一個tomcat掛掉後,叢集會將使用者的存取定位到備tomcat上,然後根據cookie中儲存的SessionId找session,找不到時,再去對應的memcached上去session,找到之後將其複製到備tomcat上。

Linux叢集/分散式環境下session處理方法介紹

② 非黏性session處理方式

原理:memcached做主從複製,寫入session都往從memcached服務上寫,讀取都從主memcached讀取,tomcat本身不儲存session

Linux叢集/分散式環境下session處理方法介紹

#優點:可容錯,session即時回應。

實作方式:用開源的msm外掛程式解決tomcat之間的session共享:Memcached_Session_Manager(MSM)

a. 复制相关jar包到tomcat/lib 目录下

JAVA memcached客户端:spymemcached.jarmsm项目相关的jar包:1. 核心包,memcached-session-manager-{version}.jar2. Tomcat版本对应的jar包:memcached-session-manager-tc{tomcat-version}-{version}.jar序列化工具包:可选kryo,javolution,xstream等,不设置时使用jdk默认序列化。
登入後複製

b. 配置Context.xml ,加入处理Session的Manager

粘性模式配置:

Linux叢集/分散式環境下session處理方法介紹

非粘性配置:

Linux叢集/分散式環境下session處理方法介紹 

第四种:session持久化到数据库

原理:就不用多说了吧,拿出一个数据库,专门用来存储session信息。保证session的持久化。

优点:服务器出现问题,session不会丢失

缺点:如果网站的访问量很大,把session存储到数据库中,会对数据库造成很大压力,还需要增加额外的开销维护数据库。

第五种terracotta实现session复制

原理:Terracotta的基本原理是对于集群间共享的数据,当在一个节点发生变化的时候,Terracotta只把变化的部分发送给Terracotta服务器,然后由服务器把它转发给真正需要这个数据的节点。可以看成是对第二种方案的优化。

Linux叢集/分散式環境下session處理方法介紹

优点:这样对网络的压力就非常小,各个节点也不必浪费CPU时间和内存进行大量的序列化操作。把这种集群间数据共享的机制应用在session同步上,既避免了对数据库的依赖,又能达到负载均衡和灾难恢复的效果。

实现方式:篇幅原因,下篇再论。

小结

以上讲述的就是集群或分布式环境下,session的5种处理策略。其中就应用广泛性而言,第三种方式,也就是基于第三方缓存框架共享session,应用的最为广泛,无论是效率还是扩展性都很好。而Terracotta作为一个JVM级的开源群集框架,不仅提供HTTP Session复制,它还能做分布式缓存,POJO群集,跨越群集的JVM来实现分布式应用程序协调等,也值得学习一下。

以上是Linux叢集/分散式環境下session處理方法介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

vscode需要什麼電腦配置 vscode需要什麼電腦配置 Apr 15, 2025 pm 09:48 PM

VS Code 系統要求:操作系統:Windows 10 及以上、macOS 10.12 及以上、Linux 發行版處理器:最低 1.6 GHz,推薦 2.0 GHz 及以上內存:最低 512 MB,推薦 4 GB 及以上存儲空間:最低 250 MB,推薦 1 GB 及以上其他要求:穩定網絡連接,Xorg/Wayland(Linux)

Linux體系結構:揭示5個基本組件 Linux體系結構:揭示5個基本組件 Apr 20, 2025 am 12:04 AM

Linux系統的五個基本組件是:1.內核,2.系統庫,3.系統實用程序,4.圖形用戶界面,5.應用程序。內核管理硬件資源,系統庫提供預編譯函數,系統實用程序用於系統管理,GUI提供可視化交互,應用程序利用這些組件實現功能。

vscode終端使用教程 vscode終端使用教程 Apr 15, 2025 pm 10:09 PM

vscode 內置終端是一個開發工具,允許在編輯器內運行命令和腳本,以簡化開發流程。如何使用 vscode 終端:通過快捷鍵 (Ctrl/Cmd ) 打開終端。輸入命令或運行腳本。使用熱鍵 (如 Ctrl L 清除終端)。更改工作目錄 (如 cd 命令)。高級功能包括調試模式、代碼片段自動補全和交互式命令歷史。

git怎麼查看倉庫地址 git怎麼查看倉庫地址 Apr 17, 2025 pm 01:54 PM

要查看 Git 倉庫地址,請執行以下步驟:1. 打開命令行並導航到倉庫目錄;2. 運行 "git remote -v" 命令;3. 查看輸出中的倉庫名稱及其相應的地址。

notepad怎麼運行java代碼 notepad怎麼運行java代碼 Apr 16, 2025 pm 07:39 PM

雖然 Notepad 無法直接運行 Java 代碼,但可以通過借助其他工具實現:使用命令行編譯器 (javac) 編譯代碼,生成字節碼文件 (filename.class)。使用 Java 解釋器 (java) 解釋字節碼,執行代碼並輸出結果。

vscode在哪寫代碼 vscode在哪寫代碼 Apr 15, 2025 pm 09:54 PM

在 Visual Studio Code(VSCode)中編寫代碼簡單易行,只需安裝 VSCode、創建項目、選擇語言、創建文件、編寫代碼、保存並運行即可。 VSCode 的優點包括跨平台、免費開源、強大功能、擴展豐富,以及輕量快速。

Linux的主要目的是什麼? Linux的主要目的是什麼? Apr 16, 2025 am 12:19 AM

Linux的主要用途包括:1.服務器操作系統,2.嵌入式系統,3.桌面操作系統,4.開發和測試環境。 Linux在這些領域表現出色,提供了穩定性、安全性和高效的開發工具。

vscode終端命令不能用 vscode終端命令不能用 Apr 15, 2025 pm 10:03 PM

VS Code 終端命令無法使用的原因及解決辦法:未安裝必要的工具(Windows:WSL;macOS:Xcode 命令行工具)路徑配置錯誤(添加可執行文件到 PATH 環境變量中)權限問題(以管理員身份運行 VS Code)防火牆或代理限制(檢查設置,解除限制)終端設置不正確(啟用使用外部終端)VS Code 安裝損壞(重新安裝或更新)終端配置不兼容(嘗試不同的終端類型或命令)特定環境變量缺失(設置必要的環境變量)

See all articles