设为首页 收藏本站
查看: 980|回复: 0

[经验分享] apache+tomcat实现session共享

[复制链接]

尚未签到

发表于 2017-12-24 06:33:51 | 显示全部楼层 |阅读模式
  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
DSC0000.jpg

  tomcat2
DSC0001.jpg

  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 下载:http://cvs.apache.org/~fhanik/tomcat-replication.jar如果是二台机器,可以用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 http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
  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/);
  %>
test.jsp:<%@ page contentType="text/html; " %><%@ page import="java.util.*" %><html><head><title>Cluster App Test</title></head><body>Server Info:<%out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>");%><%  out.println("<br>>  String dataName = request.getParameter("dataName");  session.setAttribute("myname","session?");  if (dataName != null && dataName.length() > 0) {     String dataValue = request.getParameter("dataValue");     session.setAttribute(dataName, dataValue);  }  out.print("<b>Session P±?b>");  Enumeration e = session.getAttributeNames();  while (e.hasMoreElements()) {     String name = (String)e.nextElement();     String value = session.getAttribute(name).toString();     out.println( name + " = " + value+"<br>");         System.out.println( name + " = " + value);   }%>  <form action="index.jsp" method="POST">    3?<input type=text>     <br>    ?:<input type=text>     <br>    <input type=submit>   </form></body>  </html>
重启所有的服务。 访问http://192.168.19.199/test/print.jsp如图可以看出tomcat 集群配置完成 DSC0002.gif Session 复制的查看:在同一窗口,输入名称和值,在2个tomcat日志里能看到同样内容的日志,就表明成功了。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-427391-1-1.html 上篇帖子: Apache Ant 生成项目易如反掌 下篇帖子: Springboot集成权限管理框架apache shiro
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表