集羣環境下session共享

本文轉自:雪山上的蒲公英

配置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 的addressport來區分的。tomcat集羣的實例如果在Membership配置中有相同的addressport值的tomcat被分到同一個集羣裏邊。他們的session是相互共享的,同一個session的集羣被稱爲一個cluster。可以配置多個cluster,但是clustercluster之間的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,後期會測試並整理。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章