使用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复制


相关内容

热门资讯

终于懂了“普通扑克三公保庄大有... 您好:普通扑克三公保庄大这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家...
【第一消息】“天天爱泰州麻将是... 您好:天天爱泰州麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这...
【今日要闻】“阿拉斗牌有挂吗?... 【今日要闻】“阿拉斗牌有挂吗?”(确实真的有挂)您好,阿拉斗牌这个游戏其实有挂的,确实是有挂的,需要...
终于懂了“AGPoker怎么装... 家人们!今天小编来为大家解答AGPoker透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪...
终于了解“葫芦娃犇犇是不是有挂... 家人们!今天小编来为大家解答葫芦娃犇犇透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里买...
玩家攻略科普“新蓝鲸拼三张到底... 家人们!今天小编来为大家解答新蓝鲸拼三张透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里...
今日重大发现“hhpoker可... 家人们!今天小编来为大家解答hhpoker透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪...
今日重大通报“牵手跑胡子怎么装... 网上科普关于“牵手跑胡子有没有挂”话题很是火热,小编也是针对牵手跑胡子作*弊开挂的方法以及开挂对应的...
今日重磅消息“闲来贵州麻将开挂... 家人们!今天小编来为大家解答闲来贵州麻将透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里...
今日重磅消息“新圣游牌九到底是... 有 亲,根据资深记者爆料新圣游牌九是可以开挂的,确实有挂(咨询软件无需打...