zoukankan      html  css  js  c++  java
  • Ngnix(二)—— Nginx+tomcat集群的session共享问题

    请求负载过程中会话信息不能丢失.那么需要在多个tomcat中session需要共享.所以需要进行相关问题的解决

    配置Tomcat的session共享可以有三种解决方案:

    第一种:是以负载均衡服务器本身提供的session共享策略,每种服务期的配置是不一样的并且nginx本身是没有的。

    第二种:是利用web容器本身的session共享策略来配置共享。针对于weblogic这种方式还是靠普的。但是针对于tomcat这种方式存在很大的缺陷,主要因为是依靠广播方式来实现的session复制,会浪费很多带宽导致整个网络反映缓慢。官网也建议这种方式最好不要超过4台tomcat,具体的内容可参考/webapps/docs/cluster-howto.html里面有详细的说明。下面是具体的配置过程

    第三种:是Tomcat集群+redis的Session共享配置方法.

    在这里我们以第二种方式为例:

    步骤一:修改server.xml文件,最简单的集群配置只需要将节点中注释掉的下面这句取消注释即可:

    Xml代码:
    
        <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/> 

    使用这样方法配置的集群会将Session同步到所在网段上的所有配置了集群属性的实例上(此处讲所在网段可能不准确,是使用Membership 的address和port来区分的。tomcat集群的实例如果在Membership配置中有相同的address和port值的tomcat被分到同一个集群里边。他们的session是相互共享的,同一个session的集群被称为一个cluster。可以配置多个cluster,但是cluster和cluster之间的session是不共享的)。也就是说如果该广播地址下的所有Tomcat实例都会共享Session,那么假如有几个互不相关的集群,就可能造成Session复制浪费,所以为了避免浪费就需要对节点多做点设置了,如下:

    Xml代码
    
        <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster">   
    
            <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"/>   
    
            </Channel>   
    
        </Cluster> 

    加了一个Channel,里面包了个Membership,咱们要关注的就是membership的port属性和address属性,不同的集群设置不同的port值或address值,从目前的使用来看,基本上是隔离开了。

     

    步骤二:修改项目的web.xml文件:

    web.xml文件的修改很简单:只需要在节点中添加这个节点<distributable/>就可以了。

    OK,有了这二步就实现了Tomcat的集群和Session的共享了。

     

     

     

  • 相关阅读:
    创业艰难
    2013.5.20 a
    碱基对
    安装免费在线客服livezilla系统
    简单实现后台订单页面 上一单,下一单 的按钮
    zencart新进产品滚动
    ZEN CART 一级分类显示所有二级分类产品
    frame弹出框
    zen cart 打开错误信息显示调试开关
    zencart外贸网站促销方案
  • 原文地址:https://www.cnblogs.com/myfaith-feng/p/9727341.html
Copyright © 2011-2022 走看看