Nginx+Redis+Tomcat实现负载均衡项目session共享

nginx 专栏收录该内容
4 篇文章 0 订阅

本篇文章是继前三篇文章实现的基础上完成的,如果在阅读过程中,有没安装或没实现的功能,请参考前两篇博客。

Linux系统下Nginx的安装 :讲述nginx在Linux系统下的安装工程,以及设置为自启动服务。

Nginx反向代理转发tomcat :讲述nginx反向代理原理,转发tomcat实现过程以及动、静资源分离处理。

Nginx+Tomcat搭建高性能负载均衡集群:讲述nginx和tomcat实现负载均衡。


1.运行环境要求

nginx安装成功,redis安装成功。

tomcat服务分为两个,分别是:

名称IP端口
tomcat1172.16.21.928080
tomcat2172.16.21.928081


2.下载相关jar包

jedis-2.5.2:http://central.maven.org/maven2/redis/clients/jedis/2.5.2/jedis-2.5.2.jar

commons-pool2-2.0:http://central.maven.org/maven2/org/apache/commons/commons-pool2/2.0/commons-pool2-2.0.jar

tomcat-redis-session-manager:http://download.csdn.net/detail/mlc1218559742/9682304

下载这三个jar包,分别放到两个tomcat的lib目录中。


3.修改context.xml

将两个tomcat的context.xml配置分别修改为如下图所示;


添加内容为:

    <Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />
    <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"
     host="172.16.21.92"
     port="7003"
     database="0"
     maxInactiveInterval="60" />

host:redis的IP地址。

port:redis的端口号。

database:默认为0,这里用不到,暂时不用管。

maxinactiveinterval :最大不活动时间,默认为60


4.修改nginx.conf

配置修改如下:


途中红框中的配置表示当一台server宕机,切换速度会很快,此时配置是1秒。

nginx采用轮询的方式访问两台服务器。


5.编写测试页面

首先得有登录页面,登录成功进入测试页面,验证session是否共享。

下面是tomcat1服务器测试页面代码:

<body>
<h2>这是Tomcat1</h2>
<h2>session id : ${pageContext.session.id}</h2>
<h2>session time : ${pageContext.session.creationTime}</h2>
</body>

tomcat2测试页面代码:

<body>
<h2>这是Tomcat2</h2>
<h2>session id : ${pageContext.session.id}</h2>
<h2>session time : ${pageContext.session.creationTime}</h2>
</body>

6.验证结果

第一次登录,进入测试页面,发现客户端请求被nginx转发到了tomcat1服务器中,打印出sessionid和session创建时间的信息,如下图所示:

刷新页面,客户端的请求发送的请求别nginx转发到了转发到了tomcat2服务器中,但是打印出来session的信息和tomcat1服务器中session信息一模一样。


通过上面的验证,Nginx+Redis+Tomcat session共享已经成功实现。


  • 1
    点赞
  • 0
    评论
  • 2
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

©️2021 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值