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服务分为两个,分别是:
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配置分别修改为如下图所示;
添加内容为:
host:redis的IP地址。
port:redis的端口号。
database:默认为0,这里用不到,暂时不用管。
maxinactiveinterval :最大不活动时间,默认为60
4.修改nginx.conf
配置修改如下:
途中红框中的配置表示当一台server宕机,切换速度会很快,此时配置是1秒。
nginx采用轮询的方式访问两台服务器。
5.编写测试页面
首先得有登录页面,登录成功进入测试页面,验证session是否共享。
下面是tomcat1服务器测试页面代码:
tomcat2测试页面代码:
6.验证结果
第一次登录,进入测试页面,发现客户端请求被nginx转发到了tomcat1服务器中,打印出sessionid和session创建时间的信息,如下图所示:
刷新页面,客户端的请求发送的请求别nginx转发到了转发到了tomcat2服务器中,但是打印出来session的信息和tomcat1服务器中session信息一模一样。
通过上面的验证,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 |
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共享已经成功实现。
相关文章推荐
- tomcat+nginx+redis实现均衡负载、session共享---项目默认路径找不到
- 负载均衡之Nginx+tomcat+redis实现session共享的负载均衡
- 负载均衡之Nginx+tomcat+redis实现session共享的负载均衡
- tomcat+nginx+redis实现均衡负载、session共享(二)
- tomcat+nginx+redis实现均衡负载、session共享(一)
- (转)tomcat+nginx+redis实现均衡负载、session共享(二)
- tomcat+nginx+redis实现均衡负载、session共享
- tomcat+nginx+redis实现均衡负载、session共享(一)
- tomcat+nginx+redis实现均衡负载、session共享(一)
- tomcat+nginx+redis实现均衡负载、session共享
- Redis学习笔记(六)Nginx+Tomcat+Redis实现负载均衡、资源分离、session共享
- Nginx+Tomcat+Redis实现负载均衡、资源分离、session共享
- nginx+tomcat+redis 做负载均衡时session 共享实现
- tomcat+nginx+redis实现均衡负载、session共享(二)
- tomcat+nginx+redis实现均衡负载、session共享---让Tomcat把会话Session保存到Redis数据库。
- nginx+tomcat+redis实现负载均衡、动静分离、session共享
- tomcat+nginx+redis实现均衡负载、session共享---(推荐)
- tomcat+nginx+redis实现均衡负载、session共享(一)
- tomcat+nginx+redis实现均衡负载、session共享(二)
- tomcat+nginx+redis实现均衡负载、session共享