如何实现Nginx+tomcat负载均衡的会话保持

发布时间:2021-12-13 09:36:40 作者:小新
来源:亿速云 阅读:241

小编给大家分享一下如何实现Nginx+tomcat负载均衡的会话保持,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

 什么是会话保持

会话是指一个终端用户与交互系统进行通讯的过程,比如从输入账户密码进入操作系统到退出操作系统就是一个会话过程。会话较多用于网络上,TCP的三次握手就创建了一个会话,TCP关闭连接就是关闭会话。

Http协议是一种无状态协议,所以需要使用Session机制来保存用户的状态,比如登录状态、常用信息等。

如何实现Nginx+tomcat负载均衡的会话保持

Session用于保存一次会话的相关信息,可以实现在多个页面之间共享这些数据。

如何实现Nginx+tomcat负载均衡的会话保持

如何实现Nginx+tomcat负载均衡的会话保持

例如:你打开淘宝登录了个人账号,即使你浏览了再多的店铺宝贝,切换了很多的页面,用户名是不变的,这个就是Session起的作用。直到你关闭浏览器,Session被销毁,才会清除掉之前的登录记录。

今天和大家分享“Nginx+tomcat实现负载均衡的会话保持”就是实现:如果网站某个负载节点挂掉,请求被分配到新节点Session也会同步过来,实现会话保持,由此保证用户无感知的浏览。

实现原理

如何实现Nginx+tomcat负载均衡的会话保持

实验配置

Nginx配置

如何实现Nginx+tomcat负载均衡的会话保持

测试环境单台服务器开了两个tomcat,一台对应8080端口,另一台对应8090端口。

创建TomcatA TomcatB,分别配置tomcat server.xml

复制以下内容到 Engine下

添加此模块:

如何实现Nginx+tomcat负载均衡的会话保持

<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"/>  <Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"  address="192.168.224.145"  port="4001"  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.MessageDispatch25Interceptor"/>  </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.JvmRouteSessionIDBinderListener"/>  <ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>  </Cluster>

备注:

1.classname配置tomcat集群在进行信息传递时互相使用什么类来进行传递

2.manager决定如何管理集群的session信息

3.Channel是Tomcat节点之间进行通讯的工具。

4.Membership维护集群的可用节点列表。用于检测新增节点及掉线节点

5.Receiver : 接收器

如果port为4000,autoBind为100,接收器将在4000-4099间取一个端口,进行监听

6.sender:发送器负责发送消息

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

7.Valve :过滤器

8.Deployer:同步集群下的所有节点的一致性

9.ClusterListener :  监听器,监听Cluster组件接收的消息,使用DeltaManager时,Cluster接收的信息通过ClusterSessionListener传递给DeltaManager

配置web.xml

在web.xml中添加属性,用于告诉web容器,该项目属于分布式项目

添加标签到web项目WEB-INF目录

如何实现Nginx+tomcat负载均衡的会话保持

会话保持验证

webapps/ROOT/index.jsp 创建测试页面获取sessionID

tomcatA  <%@ page language="java" %>  <html>  <head><title>TomcatA</title></head>  <body>  <h2><font color="red">TomcatA</font></h2>  <table align="centre" border="1">  <tr>  <td>Session ID</td>  <% session.setAttribute("TomcatA","TomcatA"); %>  <td><%= session.getId() %></td>  </tr>  <tr>  <td>Created on</td>  <td><%= session.getCreationTime() %></td>  </tr>  </table>  </body> </html> tomcatB <%@ page language="java" %> <html>  <head><title>TomcatB</title></head>  <body>  <h2><font color="red">TomcatB</font></h2>  <table align="centre" border="1">  <tr>  <td>Session ID</td>  <% session.setAttribute("TomcatB","TomcatB"); %>  <td><%= session.getId() %></td>  </tr>  <tr>  <td>Created on</td>  <td><%= session.getCreationTime() %></td>  </tr>  </table>  </body> </html>

浏览器访问验证

如何实现Nginx+tomcat负载均衡的会话保持

如何实现Nginx+tomcat负载均衡的会话保持

以上是“如何实现Nginx+tomcat负载均衡的会话保持”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

推荐阅读:
  1. Nginx+Tomcat负载均衡群集
  2. tengine会话保持功能

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

nginx tomcat

上一篇:weblogic CVE-2021-2109ldap远程代码执行漏洞的复现是怎样的

下一篇:php如何去除标签的属性

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》