日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Nginx >内容正文

Nginx

Nginx+tomcat集群的session共享问题

發布時間:2025/3/15 Nginx 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Nginx+tomcat集群的session共享问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

請求負載過程中會話信息不能丟失.那么需要在多個tomcat中session需要共享.所以需要進行相關問題的解決

配置Tomcat的session共享可以有三種解決方案:

第一種:是以負載均衡服務器本身提供的session共享策略,每種服務期的配置是不一樣的并且nginx本身是沒有的。

第二種:是利用web容器本身的session共享策略來配置共享。針對于weblogic這種方式還是靠普的。但是針對于tomcat這種方式存在很大的缺陷,主要因為是依靠廣播方式來實現的session復制,會浪費很多帶寬導致整個網絡反映緩慢。官網也建議這種方式最好不要超過4臺tomcat,具體的內容可參考/webapps/docs/cluster-howto.html里面有詳細的說明。下面是具體的配置過程

第三種:是Tomcat集群+redis的Session共享配置方法.

在這里我們以第二種方式為例:

步驟一:修改server.xml文件,最簡單的集群配置只需要將節點中注釋掉的下面這句取消注釋即可:

Xml代碼:<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>

使用這樣方法配置的集群會將Session同步到所在網段上的所有配置了集群屬性的實例上(此處講所在網段可能不準確,是使用Membership 的address和port來區分的。tomcat集群的實例如果在Membership配置中有相同的address和port值的tomcat被分到同一個集群里邊。他們的session是相互共享的,同一個session的集群被稱為一個cluster。可以配置多個cluster,但是cluster和cluster之間的session是不共享的)。也就是說如果該廣播地址下的所有Tomcat實例都會共享Session,那么假如有幾個互不相關的集群,就可能造成Session復制浪費,所以為了避免浪費就需要對節點多做點設置了,如下:

Xml代碼<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"> <Channel className="org.apache.catalina.tribes.group.GroupChannel"> <Membership className="org.apache.catalina.tribes.membership.McastService" address="228.0.0.4" port="45564" frequency="500" dropTime="3000"/> </Channel> </Cluster>

?

加了一個Channel,里面包了個Membership,咱們要關注的就是membership的port屬性和address屬性,不同的集群設置不同的port值或address值,從目前的使用來看,基本上是隔離開了。

?

步驟二:修改項目的web.xml文件:

web.xml文件的修改很簡單:只需要在節點中添加這個節點<distributable/>就可以了。

OK,有了這二步就實現了Tomcat的集群和Session的共享了。

?

?

?

轉載于:https://www.cnblogs.com/myfaith-feng/p/9727341.html

總結

以上是生活随笔為你收集整理的Nginx+tomcat集群的session共享问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。