nginx+tomcat实现负载均衡,使用redis session共享

2019-10-17 19:13:53王振洲

$ wget http://download.redis.io/releases/redis-3.2.3.tar.gz
$ tar xzf redis-3.2.3.tar.gz
$ cd redis-3.2.3
$ make MALLOC=libc
#启动redis src前面是安装的路径
$ src/redis-server &

#关闭redis
src/redis-cli shutdown
#使用redis 放入键值对 key value
$ src/redis-cli
127.0.0.1:6379> set foo bar
OK
127.0.0.1:6379> get foo
"bar"
$

安装完redis之后,在三个tomcat的lib文件夹内分别上传这五个所依赖的jar,分别是

commons-pool2-2.0.jar

jedis-2.5.2.jar

tomcat-redis-session-manager1.2.jar

tomcat-juli.jar

tomcat-juli-adapters.jar

所有jar在这里了,下载地址

然后分别修个三个tomcat的context.xml文件,增加如下的配置

<?xml version='1.0' encoding='utf-8'?>

<Context>

 <!-- Default set of monitored resources -->
 <WatchedResource>WEB-INF/web.xml</WatchedResource>

 
 <!-- 这里增加redis session共享的配置 6379是redis的端口-->
 <Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" /> 
 <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager" 
 host="127.0.0.1" 
 port="6379" 
 database="0" 
 maxInactiveInterval="60" /> 
</Context>

这时候,分别重启三个tomcat以及nginx,查看tomcat日志之后,发现没有任何异常报错,说明我们成功了,接下来开始测试。

我们访问nginx服务器地址:http://192.168.1.133:81/

得到的是8080端口的 tomcat1 ,session id为1A0625767F27BA95EF4D5F061FE0568D 

这时候按F5刷新页面,得到的是8081端口的 tomcat2 ,session id依旧是 1A0625767F27BA95EF4D5F061FE0568D

再次刷新页面,得到的是8082端口的 tomcat3,session id依旧是 1A0625767F27BA95EF4D5F061FE0568D。 、

这时候,说明我们搭建tomcat + nginx负载均衡 + redis session同步成功啦!

nginx帮助把我们的请求均匀的分发给三个tomcat --》tomcat1 、tomcat2以及tomcat3

 redis帮助我们同步session,这样一来,我们的服务器性能就会提高许多,任何一台tomcat发生故障后,对整体的服务都不会有影响了。