美文网首页tomcat
tomcat-session 共享

tomcat-session 共享

作者: 宇晨棒棒的 | 来源:发表于2019-11-13 09:55 被阅读0次

0.session的了解

在计算机中,尤其是在网络应用中,称为“会话控制”。Session 对象存储特定用户会话所需的属性及配置信息。这样,当用户在应用程序的 Web 页之间跳转时,存储在 Session 对象中的变量将不会丢失,而是在整个用户会话中一直存在下去。当用户请求来自应用程序的 Web 页时,如果该用户还没有会话,则 Web 服务器将自动创建一个 Session 对象。当会话过期或被放弃后,服务器将终止该会话

一.在集群系统下实现session统一的有如下几种方案:

1、请求精确定位:session sticky,

例如nginx基于访问ip的hash策略,即当前用户的请求都集中定位到一台服务器中,这样单台服务器保存了用户的session登录信息,如果宕机,则等同于单点部署,会丢失,会话不复制

2.session复制共享:session replication

tomcat自带session共享,主要是指集群环境下,多台应用服务器之间同步session,使session保持一致,对外透明。 如果其中一台服务器发生故障,根据负载均衡的原理,调度器会遍历寻找可用节点,分发请求,由于session已同步,故能保证用户的session信息不会丢失,会话复制.

不足之处:

1)必须在同一种中间件之间完成(比如tomcat-tomcat之间),

2)session复制带来的性能损失会快速增加,特别是当session中保存了较大的对象,而且对象变化较快时, 性能下降更加显著,会消耗系统性能。这种特性使得web应用的水平扩展受到了限制。

3)Session内容通过广播同步给成员,会造成网络流量瓶颈,即便是内网瓶颈

4)在大并发下表现并不好

3.基于 memcache/redis缓存的 session 共享

用cacheDB存取session信息,应用服务器接受新请求将session信息保存在cache DB中,当应用服务器发生故障时,调度器会遍历寻找可用节点,分发请求,当应用服务器发现session不在本机内存时,则去cacheDB中查找,如果找到则复制到本机,这样实现session共享和高可用

二.实验环境:

nginx  ----> 后面有两个tomcat(一台服务器两个tomcat)

此处ngixn安装,jdk tomcat安装省略。

0.tomcat的访问地址:

tomcat   192.168.9.174:8080

tomcat2:  192.168.9.174:8081  ---->修改8005,8009,8080的端口

1.编写脚本查看sessionid

A.mkdir /usr/local/{tomcat,tomcat2}/webapps/demo

vim index.jps

index.jsp

C.重新启动tomcat  :   /usr/local/tomcat/bin/shutdown.sh &&  /usr/local/tomcat/bin/startup.sh

D.查看效果(只有sessionID是不同的,还有来自那台服务器的返回):

tomcat tomcat2

2.配置session共享:

A.修改配置文件:  server.xml

在Server.xml中,找到被注释<Cluster/>节点,在下面添加如下内容

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

    <Manager className="org.apache.catalina.ha.session.DeltaManager" expireSessionsOnShutdown="false" notifyListenersOnReplication="true" />

    <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" />

        <!-- 这里如果启动出现异常,则可以尝试把address中的"auto"改为"localhost" -->

        <Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver" address="localhost" port="4000"

                  autoBind="100" selectorTimeout="5000" maxThreads="6" />

        <Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">

            <Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender" />

        </Sender>

        <Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector" />

        <Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatchInterceptor" />

    </Channel>

    <Valve className="org.apache.catalina.ha.tcp.ReplicationValve" filter="" />

    <Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve" />

    <Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer" tempDir="/tmp/war-temp/"

              deployDir="/tmp/war-deploy/" watchDir="/tmp/war-listen/" watchEnabled="false" />

    <ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener" />

</Cluster>

B.修改web.xml文件:

添加标签<distributable/>

mkdir /usr/local/{tomcat,tomcat2}/webapps/demo/WEB-INF

cp /usr/local/tomcat/ROOT/web.xml   /usr/local/{tomcat,tomcat2)/webapps/demo/WEB-INF

D.重新启动tomcat:

  /usr/local/tomcat/bin/shutdown.sh &&  /usr/local/tomcat/bin/startup.sh

E.查看端口监听状态:

端口监听

F:关闭防火墙和selinux

/etc/init.d/iptables stop  && setenforce 0 

3.配置nginx:

A.修改配置文件:

nginx配置文件

B:修改防火墙端口8002

-A INPUT -m state --state NEW -m tcp -p tcp --dport 8002 -j ACCEPT

/etc/init.d/iptables restart 

C.重新启动nginx:

/usr/local/nginx/sbin/nginx -s reload

4.测试:

tomcat-8080 tomcat-8081

注意:

目前此实验只成功于一台服务器多个tomcat并且访问的项目名一致。

相关文章

网友评论

    本文标题:tomcat-session 共享

    本文链接:https://www.haomeiwen.com/subject/jkbubctx.html