可通過下面方法限制一個用戶訪問一個服務器之后就只在該服務器上操作。
請求負載過程中會話信息不能丟失。那么在多個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,后期會測試並整理。