apache+tomcat上篇文章,实现了负载均衡,现在我们实现session共享
一、tomcat集群配置,session 同步配置:
tomcat1配置
A、修改Engine节点信息: <Engine name=”Catalina” defaultHost=”localhost” jvmRoute=”tomcat1″>
B、去掉<Cluster> </Cluster> 的注释符
C、修改Cluster 节点信息
<Membership
className=”org.apache.catalina.cluster.mcast.McastService”
mcastBindAddress=”127.0.0.1″
#IP自己配置,远程的话写远程IP
mcastAddr=”224.0.0.1″
mcastPort=”45564″
mcastFrequency=”500″
mcastDropTime=”3000″/>
<Receiver
className=”org.apache.catalina.cluster.tcp.ReplicationListener”
tcpListenAddress=”127.0.0.1″
tcpListenPort=”4001″
tcpSelectorTimeout=”100″
tcpThreadCount=”6″/>
tomcat2配置:
A、修改Engine节点信息: <Engine name=”Catalina” defaultHost=”localhost” jvmRoute=”tomcat2″>
B、去掉<Cluster> </Cluster> 的注释符
C、修改Cluster 节点信息
<Membership
className=”org.apache.catalina.cluster.mcast.McastService”
mcastBindAddress=”127.0.0.1″
#IP自己配置
mcastAddr=”224.0.0.1″
mcastPort=”45564″
mcastFrequency=”500″
mcastDropTime=”3000″/>
<Receiver
className=”org.apache.catalina.cluster.tcp.ReplicationListener”
tcpListenAddress=”127.0.0.1″
#IP自己配置
tcpListenPort=”4002″
# 一定要改
tcpSelectorTimeout=”100″
tcpThreadCount=”6″/>
修改web应用里面WEB-INF目录下的web.xml文件,加入标签
<distributable/>
直接加在</web-app>之前就可以了
做tomcat集群必须需要这一步,否则用户的session就无法正常使用。
注意事项:
1、mcastAddr=”224.0.0.1″这主广播地址因此需要开启网卡组播功能
route add -net 224.0.0.0 netmask 240.0.0.0 dev eth0
分别在各机器上运行
2、查看端口情况:Netstat –antl |grep 4001 同步监听的端口(2台tomcat在不同机器情况下)
tocat1
tomcat2
3、测试广播:
java -cp tomcat-replication.jar MCaster 224.0.0.1 45564 Terminal1
java -cp tomcat-replication.jar MCaster 224.0.0.1 45564 Terminal2
如果不报错则能正常广播tomcat-replication.jar 下载:[url]http://cvs.apache.org/~fhanik/tomcat-replication.jar[/url]如果是二台机器,可以用tcpdump 抓取包
二、测试集群及session同步
在2个tomct的webapps 下新建test 目录目录下建WEB-INF目录下的web.xml文件
<web-app xmlns=”http://java.sun.com/xml/ns/j2ee”
xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance“
xsi:schemaLocation=”http://java.sun.com/xml/ns/j2ee [url]http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd[/url]”
version=”2.4″>
<display-name>TomcatDemo</display-name>
<distributable/>
</web-app>
再在webapps 下建立print.jsptest.jsp
Print.jsp :
<%
System.out.println(“http://andashu.blog.51cto.com/);
%>
</html>
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/tech/opensource/191834.html