本文轉自:雪山上的蒲公英
配置tomcat的session共享
<div class="postBody">
<div id="cnblogs_post_body" class="blogpost-body"><p class="16"><span style="font-family: 宋體;"> 可通過下面方法<strong>限制一個用戶訪問一個服務器之後就只在該服務器上操作</strong>。</span></p>
請求負載過程中會話信息不能丟失。那麼在多個tomcat中session需要共享。
配置tomcat的session共享可以有三種解決方案:
第一種是以負載均衡服務器本身提供的session共享策略,每種服務器的配置是不一樣的,並且nginx本身是沒有的。這裏不做探究。
第二種是利用web容器本身的session共享策略來配置共享。
針對於weblogic這種方式還是靠譜的。但是針對於tomcat這種方式存在很大的缺陷,主要因爲是依靠廣播方式來實現的session複製,會浪費很多帶寬導致整個網絡反應緩慢。官網也建議這種方式最好不要超過4臺tomcat,具體的內容可參考/webapps/docs/cluster-howto.html裏面有詳細的說明。下面是具體的配置過程。
最簡單的方法是將server.xml裏的該行內容註釋取消,如下:
使用這樣方法配置的集羣會將session同步到所在網段上的所有配置了集羣屬性的實例上(此處講所在網段可能不準確,是使用Membership 的address和port來區分的。tomcat集羣的實例如果在Membership配置中有相同的address和port值的tomcat被分到同一個集羣裏邊。他們的session是相互共享的,同一個session的集羣被稱爲一個cluster。可以配置多個cluster,但是cluster和cluster之間的session是不共享的)。也就是說如果該廣播地址下的所有Tomcat實例都會共享Session,那麼假如有幾個互不相關的集羣,就可能造成Session複製浪費,所以爲了避免浪費就需要對節點多做點設置了,如下:
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster" channelSendOptions="8"> <Manager className="org.apache.catalina.ha.session.DeltaManager" expireSessionsOnShutdown="false" notifyListenersOnReplication="true"/> <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"/> <Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver" address="auto" port="4000" autoBind="100" selectorTimeout="5000" maxThreads="6"/> <Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter"> <Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/> </Sender> <Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/> <Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/> </Channel> <Valve className="org.apache.catalina.ha.tcp.ReplicationValve" filter=""/> <Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/> <Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer" tempDir="/tmp/war-temp/" deployDir="/tmp/war-deploy/" watchDir="/tmp/war-listen/" watchEnabled="false"/> <ClusterListener className="org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener"/> <ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/> </Cluster>
<Cluster>中加了一個<Channel>,裏面包了個<Membership>,要關注的是<Membership>的port屬性和address屬性,不同的集羣設置不同的port值或address值,從而保證session在不同集羣之間的隔離。
另外要注意,Make sure your web.xml
has the <distributable/>
element 。項目中的web.xml文件需要在節點中增加<distributable/>節點。
第三種是Tomcat集羣+redis的Session共享配置方法。
可參考http://www.cnblogs.com/zhrxidian/p/5491285.html,後期會測試並整理。