使用apache代理tomcat集群并实现session复制
admin
2023-03-20 05:01:30
0

1.系统结构图 
使用apache代理tomcat集群并实现session复制
2.准备 
主机tomcatA:关闭iptables 
主机tomcatB:关闭iptables 
主机apache:关闭iptables,关闭selinux 
3.安装软件 
安装tomcat请参考:http://blog.csdn.net/kairui123/article/details/71247618 
安装apache:yum install httpd 
4.配置appche

ProxyRequests off     //是否开启正向代理


        SetHandler balancer-manager



    ServerAdmin www.creazyrui.com
    DocumentRoot /var/www/html
    ServerName www.creazyrui.com
   

参数解释: 
loadfactor:指定权重 
route:指定主机 
5.配置tomcat

   
     
 
  
    
    

在最后追加一下内容: 
       Welcome to tomcat 
        
             welcome to tomcat   
  
  //这个元素告诉tomcat,这个时分布式的引用
 //给集群中tomcat服务器全部配置以上文件并且修改jvmRoute=“”

6.添加页面并测试

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ page import="java.util.*" %>

 
 
     test tomcat jiqun
    
        div{border: 1px dashed #0099cc;background-color: #D1EFF9;font-size:14px;margin:5px;padding:5px}    
   


    
        

当前请求所在服务器信息:

        session标识:<%=session.getId() %> 
        IP地址:<%=java.net.InetAddress.getLocalHost() %>
        临时目录:<%=System.getProperty("java.io.tmpdir") %>     
    
        

session创建表单:

                     session名称:             session值:                           
         <%        String sessionName=request.getParameter("sessionName");                    String sessionValue=request.getParameter("sessionValue");                     if(sessionName!=null && !sessionName.equals("")){             session.setAttribute(sessionName, sessionValue);         }     %>     
        

当前请求所在服务器的session列表

        <%             Enumeration e=session.getAttributeNames();                         while(e.hasMoreElements()){                                String name=(String)e.nextElement();                                String value=session.getAttribute(name).toString();                 out.println(name+"= "+value+"
");             }         %>     
         

测试结果: 
使用apache代理tomcat集群并实现session复制

使用apache代理tomcat集群并实现session复制

7.tomcat的会话管理

1.StandarManager:默认会话管理器,使用于单个运行单个运行状态的tomcat实例管理,当tomcat正常关闭时,会将session会话写入一个以SESSION.ser文件,并在下次启动时读取
2.PersistentManager:当会话长时间处于空闲状态时将被写入swap会话对象。
3.DeltaManager:用于tomcat集群会话管理通过session复制实现session共享,将改变的session同步与集群中的每一个节点
4.BackupManager:用于tomcat集群中,但与DeltaManager不同,他将会话只同步给集群中一个的节点,而不是所有。

定义StandarManager,PersistentManager会话管理器

1.定义StandarManager会话管理器,默认使用

默认保存在$CATALINA_HOME/work/Catalina///下的session
参数:
    maxActiveSession:允许最多的会话数量,-1表示不限制
    maxInactiveInterval:非活动的会话超时时间,默认伪60s
    pathname:会话文件路径
2.定义PersistentManager会话管理器,将session会话写入文件

    

参数:
    diretory:指定文件的路径
3.定义PersistentManager会话管理器,将session会话写入数据库

    

8.tomcat实现session复制 
a.编辑每个server.xml文件,将一下内容添加在engine|host标签中,配置Cluster标签


    
    
        
        
        
            
        
        
        
    
    
    
    
    
    

b.在各个节点上添加组播路由

route add -net ip netmask 255.255.255.255 dev eth011

测试结果: 
使用apache代理tomcat集群并实现session复制


相关内容

热门资讯

学习新语·政绩观|“愚公”治山... 统筹:郭洁宇 朱旭东设计:殷哲伦新华社新媒体中心新华社出品
请问瓷砖外墙做防水多少钱 已有2条回答 回复者:小休维 瓷砖外墙防水涂料60元一平方。外墙透明防水涂料无色、透明、涂覆...
旧房翻新可以直接贴壁纸吗? 不可以的。首先墙纸就不能贴在乳胶漆墙面上,因为乳胶漆的工艺、质量等都会影响到墙皮的附着力,所以在乳胶...
怎样翻新厨房瓷砖墙面?墙面瓷砖... 厨房理不管是哪一种的瓷砖,都可以在旧瓷砖上贴新的瓷砖。个别严重起鼓或者破坏的瓷砖需要革除,革除后用马...
无缝瓷砖真的可以做到无缝吗 无缝瓷砖之间的缝隙确实比较小,但是想要做到真正的无缝应该是不太可能的,据说这种无缝瓷砖每个瓷砖之间的...
瓷砖可以翻新吗 瓷砖可以翻新。瓷砖翻新的方法有多种,比如可以重新进行上色,用瓷漆在瓷砖上重新进行涂色和美化,在施工过...
庄瑞雄称沈伯洋当市长2天就能解... 海峡导报综合报道 台民意机构民进党团干事长庄瑞雄日前称,鼠患是城市治理的问题,蒋万安必须要展现市长的...
双层大巴撞上限高架,车头嵌入架... 5月9日,广东湛江一双层大巴撞上限高架,造成车身和限高架受损,无人受伤。相关视频显示,一辆白色双层大...
五一票房冠军是惊悚片,“下沉市... 【文/新潮观鱼】今年“五一”档,有一个有意思的现象:一部看起来没有“爆款相”,演员和导演都没有很大票...
“几轮博弈后,特朗普发现:中国... 【文/观察者网 王一】当地时间5月9日,英国《金融时报》发长文分析称,在美国与中国围绕贸易、科技、地...