您的位置:首页 > 数据库 > Redis

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

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

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共享已经成功实现。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息