【Linux運(yùn)維-集群技術(shù)進(jìn)階】集群/分布式環(huán)境下5種session處理策略

來(lái)源:極客頭條

在搭建完集群環(huán)境后剥险,不得不考慮的一個(gè)問題就是用戶訪問產(chǎn)生的session如何處理透硝。如果不做任何處理的話狰闪,用戶將出現(xiàn)頻繁登錄的現(xiàn)象,比如集群中存在A蹬铺、B兩臺(tái)服務(wù)器尝哆,用戶在第一次訪問網(wǎng)站時(shí),Nginx通過其負(fù)載均衡機(jī)制將用戶請(qǐng)求轉(zhuǎn)發(fā)到A服務(wù)器甜攀,這時(shí)A服務(wù)器就會(huì)給用戶創(chuàng)建一個(gè)Session秋泄。當(dāng)用戶第二次發(fā)送請(qǐng)求時(shí),Nginx將其負(fù)載均衡到B服務(wù)器规阀,而這時(shí)候B服務(wù)器并不存在Session恒序,所以就會(huì)將用戶踢到登錄頁(yè)面。這將大大降低用戶體驗(yàn)度谁撼,導(dǎo)致用戶的流失歧胁,這種情況是項(xiàng)目絕不應(yīng)該出現(xiàn)的。

我們應(yīng)當(dāng)對(duì)產(chǎn)生的Session進(jìn)行處理厉碟,通過粘性Session喊巍,Session復(fù)制或Session共享等方式保證用戶的體驗(yàn)度。

以下我將說(shuō)明5種Session處理策略箍鼓,并分析其優(yōu)劣性崭参。

第一種:粘性session

原理:粘性Session是指將用戶鎖定到某一個(gè)服務(wù)器上,比如上面說(shuō)的例子款咖,用戶第一次請(qǐng)求時(shí)何暮,負(fù)載均衡器將用戶的請(qǐng)求轉(zhuǎn)發(fā)到了A服務(wù)器上奄喂,如果負(fù)載均衡器設(shè)置了粘性Session的話,那么用戶以后的每次請(qǐng)求都會(huì)轉(zhuǎn)發(fā)到A服務(wù)器上海洼,相當(dāng)于把用戶和A服務(wù)器粘到了一塊跨新,這就是粘性Session機(jī)制。

優(yōu)點(diǎn):簡(jiǎn)單坏逢,不需要對(duì)session做任何處理域帐。

缺點(diǎn):缺乏容錯(cuò)性,如果當(dāng)前訪問的服務(wù)器發(fā)生故障是整,用戶被轉(zhuǎn)移到第二個(gè)服務(wù)器上時(shí)俯树,他的session信息都將失效。

適用場(chǎng)景:發(fā)生故障對(duì)客戶產(chǎn)生的影響較蟹〉痢;服務(wù)器發(fā)生故障是低概率事件阳欲。

實(shí)現(xiàn)方式:以Nginx為例舵盈,在upstream模塊配置ip_hash屬性即可實(shí)現(xiàn)粘性Session。

upstream mycluster{

#這里添加的是上面啟動(dòng)好的兩臺(tái)Tomcat服務(wù)器

ip_hash;#粘性Session

server 192.168.22.229:8080 weight=1;

server 192.168.22.230:8080 weight=1;

}

第二種:服務(wù)器session復(fù)制

原理:任何一個(gè)服務(wù)器上的session發(fā)生改變(增刪改)球化,該節(jié)點(diǎn)會(huì)把這個(gè) session的所有內(nèi)容序列化秽晚,然后廣播給所有其它節(jié)點(diǎn),不管其他服務(wù)器需不需要session筒愚,以此來(lái)保證Session同步赴蝇。

優(yōu)點(diǎn):可容錯(cuò),各個(gè)服務(wù)器間session能夠?qū)崟r(shí)響應(yīng)巢掺。

缺點(diǎn):會(huì)對(duì)網(wǎng)絡(luò)負(fù)荷造成一定壓力句伶,如果session量大的話可能會(huì)造成網(wǎng)絡(luò)堵塞,拖慢服務(wù)器性能陆淀。

實(shí)現(xiàn)方式:

① 設(shè)置tomcat 考余,server.xml 開啟tomcat集群功能

server.xml

Address:填寫本機(jī)ip即可,設(shè)置端口號(hào)轧苫,預(yù)防端口沖突楚堤。

② 在應(yīng)用里增加信息:通知應(yīng)用當(dāng)前處于集群環(huán)境中,支持分布式

在web.xml中添加選項(xiàng)

第三種:session共享機(jī)制

使用分布式緩存方案比如memcached含懊、redis身冬,但是要求Memcached或Redis必須是集群。

使用Session共享也分兩種機(jī)制岔乔,兩種情況如下:

① 粘性session處理方式

原理:不同的 tomcat指定訪問不同的主memcached酥筝。多個(gè)Memcached之間信息是同步的,能主從備份和高可用重罪。用戶訪問時(shí)首先在tomcat中創(chuàng)建session樱哼,然后將session復(fù)制一份放到它對(duì)應(yīng)的memcahed上哀九。memcache只起備份作用,讀寫都在tomcat上搅幅。當(dāng)某一個(gè)tomcat掛掉后阅束,集群將用戶的訪問定位到備tomcat上,然后根據(jù)cookie中存儲(chǔ)的SessionId找session茄唐,找不到時(shí)息裸,再去相應(yīng)的memcached上去session,找到之后將其復(fù)制到備tomcat上沪编。

粘性session處理方式

② 非粘性session處理方式

原理:memcached做主從復(fù)制呼盆,寫入session都往從memcached服務(wù)上寫,讀取都從主memcached讀取蚁廓,tomcat本身不存儲(chǔ)session

非粘性session處理方式

優(yōu)點(diǎn):可容錯(cuò)访圃,session實(shí)時(shí)響應(yīng)。

實(shí)現(xiàn)方式:用開源的msm插件解決tomcat之間的session共享:Memcached_Session_Manager(MSM)

a. 復(fù)制相關(guān)jar包到tomcat/lib 目錄下

JAVA memcached客戶端:spymemcached.jar

msm項(xiàng)目相關(guān)的jar包:

1. 核心包相嵌,memcached-session-manager-{version}.jar

2. Tomcat版本對(duì)應(yīng)的jar包:memcached-session-manager-tc{tomcat-version}-{version}.jar

序列化工具包:可選kryo腿时,javolution,xstream等,不設(shè)置時(shí)使用jdk默認(rèn)序列化饭宾。

b. 配置Context.xml 批糟,加入處理Session的Manager

粘性模式配置:

Context.xml

非粘性配置:

Context.xml

第四種:session持久化到數(shù)據(jù)庫(kù)

原理:就不用多說(shuō)了吧,拿出一個(gè)數(shù)據(jù)庫(kù)看铆,專門用來(lái)存儲(chǔ)session信息徽鼎。保證session的持久化。

優(yōu)點(diǎn):服務(wù)器出現(xiàn)問題弹惦,session不會(huì)丟失

缺點(diǎn):如果網(wǎng)站的訪問量很大否淤,把session存儲(chǔ)到數(shù)據(jù)庫(kù)中,會(huì)對(duì)數(shù)據(jù)庫(kù)造成很大壓力棠隐,還需要增加額外的開銷維護(hù)數(shù)據(jù)庫(kù)叹括。

第五種terracotta實(shí)現(xiàn)session復(fù)制

原理:Terracotta的基本原理是對(duì)于集群間共享的數(shù)據(jù),當(dāng)在一個(gè)節(jié)點(diǎn)發(fā)生變化的時(shí)候宵荒,Terracotta只把變化的部分發(fā)送給Terracotta服務(wù)器汁雷,然后由服務(wù)器把它轉(zhuǎn)發(fā)給真正需要這個(gè)數(shù)據(jù)的節(jié)點(diǎn)”龋可以看成是對(duì)第二種方案的優(yōu)化侠讯。

優(yōu)點(diǎn):這樣對(duì)網(wǎng)絡(luò)的壓力就非常小,各個(gè)節(jié)點(diǎn)也不必浪費(fèi)CPU時(shí)間和內(nèi)存進(jìn)行大量的序列化操作暑刃。把這種集群間數(shù)據(jù)共享的機(jī)制應(yīng)用在session同步上厢漩,既避免了對(duì)數(shù)據(jù)庫(kù)的依賴,又能達(dá)到負(fù)載均衡和災(zāi)難恢復(fù)的效果岩臣。

實(shí)現(xiàn)方式:篇幅原因溜嗜,下篇再論宵膨。

以上講述的就是集群或分布式環(huán)境下,session的5種處理策略炸宵。其中就應(yīng)用廣泛性而言辟躏,第三種方式,也就是基于第三方緩存框架共享session土全,應(yīng)用的最為廣泛捎琐,無(wú)論是效率還是擴(kuò)展性都很好。而Terracotta作為一個(gè)JVM級(jí)的開源群集框架裹匙,不僅提供HTTP Session復(fù)制瑞凑,它還能做分布式緩存,POJO群集概页,跨越群集的JVM來(lái)實(shí)現(xiàn)分布式應(yīng)用程序協(xié)調(diào)等籽御,也值得學(xué)習(xí)一下。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末惰匙,一起剝皮案震驚了整個(gè)濱河市篱蝇,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌徽曲,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,427評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件麸塞,死亡現(xiàn)場(chǎng)離奇詭異秃臣,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)哪工,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門奥此,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人雁比,你說(shuō)我怎么就攤上這事稚虎。” “怎么了偎捎?”我有些...
    開封第一講書人閱讀 165,747評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵蠢终,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我茴她,道長(zhǎng)寻拂,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,939評(píng)論 1 295
  • 正文 為了忘掉前任丈牢,我火速辦了婚禮祭钉,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘己沛。我一直安慰自己慌核,他們只是感情好距境,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,955評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著垮卓,像睡著了一般垫桂。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上扒接,一...
    開封第一講書人閱讀 51,737評(píng)論 1 305
  • 那天伪货,我揣著相機(jī)與錄音,去河邊找鬼钾怔。 笑死碱呼,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的宗侦。 我是一名探鬼主播愚臀,決...
    沈念sama閱讀 40,448評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼矾利!你這毒婦竟也來(lái)了姑裂?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,352評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤男旗,失蹤者是張志新(化名)和其女友劉穎舶斧,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體察皇,經(jīng)...
    沈念sama閱讀 45,834評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡茴厉,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,992評(píng)論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了什荣。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片矾缓。...
    茶點(diǎn)故事閱讀 40,133評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖稻爬,靈堂內(nèi)的尸體忽然破棺而出嗜闻,到底是詐尸還是另有隱情,我是刑警寧澤桅锄,帶...
    沈念sama閱讀 35,815評(píng)論 5 346
  • 正文 年R本政府宣布琉雳,位于F島的核電站,受9級(jí)特大地震影響友瘤,放射性物質(zhì)發(fā)生泄漏咐吼。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,477評(píng)論 3 331
  • 文/蒙蒙 一商佑、第九天 我趴在偏房一處隱蔽的房頂上張望锯茄。 院中可真熱鬧,春花似錦、人聲如沸肌幽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)喂急。三九已至格嘁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間廊移,已是汗流浹背糕簿。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留狡孔,地道東北人懂诗。 一個(gè)月前我還...
    沈念sama閱讀 48,398評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像苗膝,于是被迫代替她去往敵國(guó)和親殃恒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,077評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容