第一种是以负载均衡服务器自己提供的session共享策略,每种服务器的配置是不同的而且nginx自己是没有的。html
第二种是利用web容器自己的session共享策略来配置共享。针对于weblogic这种方式仍是靠普的。可是针对于tomcat这种方式存在很大的缺陷,主要由于是依靠广播方式来实现的session复制,会浪费不少带宽致使整个网络反映缓慢。官网也建议这种方式最好不要超过4台tomcat,具体的内容可参考/webapps/docs/cluster-howto.html里面有详细的说明。mysql
第三种是Tomcat集群+redis(memcache或者mysql)的Session共享配置方法。nginx
这里先记录一下第二种方式,以后再更新其余的方式web
步骤一:修改server.xml文件:redis
Xml代码:sql
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/> apache
使用这样方法配置的集群会将Session同步到所在区域上的全部配置了集群属性的实例上(这里的区域是使用Membership 的address和port来区分的。tomcat集群的实例若是在Membership配置中有相同的address和port值的tomcat被分到同一个集群里边。他们的session是相互共享的,同一个session的集群被称为一个cluster。能够配置多个cluster,可是cluster和cluster之间的session是不共享的)。也就是说若是该广播地址下的全部Tomcat实例都会共享Session,那么假若有几个互不相关的集群,就可能形成Session复制浪费,因此为了不浪费就须要对节点多作点设置了,以下:tomcat
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="192.168.18.110"
port="45564"
frequency="500"
dropTime="3000"/>
</Channel>
</Cluster>
加了一个Channel,里面包了个Membership,咱们要关注的就是membership的port属性和address属性,不一样的集群设置不一样的port值或address值,从目前的使用来看,基本上是隔离开了。
步骤二:修改项目的web.xml文件:
web.xml文件的修改很简单:只须要在节点中添加这个节点<distributable/>就能够了。