Apache集群实现Tomcat的Session共享配置其实很简单,在Tomcat自带的文档中有详细的说明( /docs/cluster-howto.html ),只不过是英语的,所以联合网上的说明,随便弄弄也出来了。
下面根据说下怎么配置吧:
1、既然是集群肯定要多准备几个Tomcat来模拟,比如分别为Tomcat01、Tomcat02、Tomcat03。
如果各Tomcat程序放在不同的机器上,那么就不会有端口的冲突。如果是放在同一台机器上的话,那就简单改几个端口,防止端口占用造成的冲突。打开conf文件夹中的server.xml文件,需要修改的端口有:
1、<Server port="8015" shutdown="SHUTDOWN"> 2、<Connector port="8081" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" /> 3、<Connector port="8019" protocol="AJP/1.3" redirectPort="8443" />
以上port需要修改,至于修改成什么样子,看你自己了,只要不出现端口冲突就可以了,要保证各个Tomcat实例间没有端口冲突
2、配置Tomcat的集群设置:
还是修改server.xml文件,最简单的集群配置只需要将<Engine/>节点中注释掉的下面这句取消注释并改为(我也是从官网上http://tomcat.apache.org/tomcat-6.0-doc/cluster-howto.html看到的)
<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>
3、修改项目的web.xml文件:
web.xml文件的修改很简单:只需要在<web-app/>节点中添加<distributable/>这个节点就可以了。
OK,有了这三步就实现了Tomcat的集群下的Session的共享了。
相关推荐
tomcat7集群实现session共享
集群session共享jar包之tomcat8。集群插件,redis方式实现session共享插件
tomcat8 Redis集群 同步Session 中用到的jar 附带tomcat content.xml配置文件
利用Redis搭建tomcat8集群所需要的jar包,已经编译好的。
NULL 博文链接:https://mukeliang.iteye.com/blog/2197850
redis+tomcat集群配置session共享
tomcat集群session共享
Nginx+Tomcat+Memcached实现tomcat集群和session共享 nginx配置
目前只支持tomcat8.5,其它版本的tomcat还没测试,自己配置过很多nginx+tomcat集群+redis实现session共享的系统,经过仔细总结得出这些,可以说是知识的结晶,欢迎大家来下载,不好的地方可以多提,有问题看到的话会...
tomcat8.5.29 redisclouder集群 session共享集群相关配置文件 亲测可用tomcat8.5.29 redisclouder集群 session共享集群相关配置文件 亲测可用 tomcat8.5.29 redisclouder集群 session共享集群相关配置文件 亲测可用 ...
完整tomcat8内含session共享包,亲自测试可以使用,有问题可以私聊。
使用说明:请严格按照资源内的readme文档来说明部署,不要搞错版本,完美支持Tomcat8和Tomcat9等新版本Tomcat,仅支持JDK8以上版本JDK。
tomcat集群session共享问题解决方案,以及应用到的相关资料
集群redis实现session共享jar包之tomcat7,此jar包可提供我博客相关demo
集群redis实现session共享jar包之tomcat7,此jar包放入tomcat的lib下。
tomcat集群使用redis解决session共享问题,压缩包包含redisclient-win32.x86.2.0客户端、Redis-x64-3.2.100服务、tomcat-redis-session以及部署安装文档
Tomcat集群配置,实现session共享 环境:jdk1.8.0_131,tomcat8
自己做的一个nginx+tomcat+redis完成session共享小例子,包括所需jar,适合初学者,希望大家一起学习交流
tomcat-redis集群时session共享jar工具类,支持tomcat8
已经配置好,只需要自己更改redis的ip地址就可以使用,请测可以使用。