zoukankan      html  css  js  c++  java
  • Tomcat集群的session共享

    配置Tomcatsession共享可以有三种解决方案:

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

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

    第三种是Tomcat集群+redis(memcache或者mysql)Session共享配置方法。

    这里先记录一下第二种方式,之后再更新其他的方式

    利用web容器本身的session共享策略来配置共享

     步骤一:修改server.xml文件:

    最简单的集群配置只需要将节点中注释掉的下面这句取消注释即可

     Xml代码:

      <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>  

    使用这样方法配置的集群会将Session同步到所在区域上的所有配置了集群属性的实例上(这里的区域是使用Membership addressport来区分的。tomcat集群的实例如果在Membership配置中有相同的addressport值的tomcat被分到同一个集群里边。他们的session是相互共享的,同一个session的集群被称为一个cluster。可以配置多个cluster,但是clustercluster之间的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="192.168.18.110"    

                    port="45564"    

                    frequency="500"    

                    dropTime="3000"/>    

            </Channel>    

        </Cluster>  

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

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

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

  • 相关阅读:
    9 种数据库中Select Top的使用方法 (只显示数据库的前几条记录)(Oracle、Infomix、DB2、SQL Server、Access、Sybase、MySQL、FoxPro、Sqlite)
    Delphi Treeview用法介绍
    TTreeView、TTreeNodes和TTreeNode
    delphi中TreeView使用
    Delphi 中多线程同步的一些处理方法
    delphi 中几种多线程操作方式
    Delphi 多线程介绍,以及线程类TThread 分析
    Delphi TTcpClient 和 TTcpServer 类 (TBaseSocket、TIpSocket、TCustomIPClient、TTcpClient、TUdpSocket、TRawSocket、TCustomTcpServer、TTcpServer) 介绍
    用NVIDIA Tensor Cores和TensorFlow 2加速医学图像分割
    通过Mellanox ConnectX NIC使用XDP加速
  • 原文地址:https://www.cnblogs.com/sMKing/p/7552388.html
Copyright © 2011-2022 走看看