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

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

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

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

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


1.运行环境要求

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

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

名称 IP 端口
tomcat1 172.16.21.92 8080
tomcat2 172.16.21.92 8081


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配置分别修改为如下图所示;

Nginx+Redis+Tomcat实现负载均衡项目session共享_第1张图片

添加内容为:

    
    

host:redis的IP地址。

port:redis的端口号。

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

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


4.修改nginx.conf

配置修改如下:

Nginx+Redis+Tomcat实现负载均衡项目session共享_第2张图片

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

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


5.编写测试页面

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

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


这是Tomcat1

session id : ${pageContext.session.id}

session time : ${pageContext.session.creationTime}


tomcat2测试页面代码:


这是Tomcat2

session id : ${pageContext.session.id}

session time : ${pageContext.session.creationTime}


6.验证结果

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

Nginx+Redis+Tomcat实现负载均衡项目session共享_第3张图片

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

Nginx+Redis+Tomcat实现负载均衡项目session共享_第4张图片

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


你可能感兴趣的:(nginx,nginx,redis,tomcat,session共享)