中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

在Linux分布式環境中對session進行處理的方法

發布時間:2021-03-08 09:20:31 來源:億速云 閱讀:265 作者:Leah 欄目:系統運維

這篇文章將為大家詳細講解有關在Linux分布式環境中對session進行處理的方法,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

什么是Linux系統

Linux是一種免費使用和自由傳播的類UNIX操作系統,是一個基于POSIX的多用戶、多任務、支持多線程和多CPU的操作系統,使用Linux能運行主要的Unix工具軟件、應用程序和網絡協議。

第一種:粘性session

原理:粘性session是指將用戶鎖定到某一個服務器上,比如上面說的例子,用戶第一次請求時,負載均衡器將用戶的請求轉發到了a服務器上,如果負載均衡器設置了粘性session的話,那么用戶以后的每次請求都會轉發到a服務器上,相當于把用戶和a服務器粘到了一塊,這就是粘性session機制。

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

缺點:缺乏容錯性,如果當前訪問的服務器發生故障,用戶被轉移到第二個服務器上時,他的session信息都將失效。

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

實現方式:以nginx為例,在upstream模塊配置ip_hash屬性即可實現粘性session。

?

1

2

3

4

5

6

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中添加選項 <distributable/>

第三種: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同步上,既避免了對數據庫的依賴,又能達到負載均衡和災難恢復的效果。

原文鏈接:http://blog.csdn.net/u010028869/article/details/50773174?ref=myread

關于在Linux分布式環境中對session進行處理的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

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

AI

麟游县| 英超| 蛟河市| 天柱县| 房产| 施秉县| 衡阳县| 沈阳市| 台南县| 易门县| 阳江市| 嘉荫县| 长海县| 旺苍县| 黄山市| 额敏县| 清远市| 阿瓦提县| 弥渡县| 昆山市| 白水县| 兴城市| 台前县| 旬邑县| 绥棱县| 松滋市| 宣威市| 广南县| 岑巩县| 易门县| 南溪县| 阿克苏市| 印江| 江孜县| 双辽市| 隆化县| 阳曲县| 甘洛县| 文成县| 石河子市| 中山市|