常用保持session的方式:
1、一些代理(比如nginxIP_hash)
1、使用数据库来存储Session
2、使用Cookie来存储Session
3、使用Redis来存储Sesssion(memcache也可以)
……
环境:
192.168.1.220 nginx centos6.6 端口:80 版本:1.9.2 192.168.1.224 tomcatA centos6.6 端口:8080 192.168.1.225 tomcatB centos6.6 端口:8090 版本:Jdk:1.7.0_75 Tomcat:7.0.54 192.168.1.223 redis 3.0.5 端口:6379 |
配置session保持并测试:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | nginx.conf配置: upstream www.tomcatcluster.com { zone myapp1 64k; server 192.168.1.224:8080 weight=1 max_fails=2fail_timeout=30s; server 192.168.1.218:8090 weight=1 max_fails=2fail_timeout=30s; } server { listen 80 default; server_name www.tomcat.com; location / { proxy_pass http: //www .tomcatcluster.com; } } |
TomcatA:TomcatB
会话保持:
编辑tomcat配置文件context.xml(TomcatA和TomcatB均操作)
1 2 3 4 5 6 7 8 9 10 11 | <Context> <Valve className= "com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" /> <ManagerclassName= "com.orangefunction.tomcat.redissessions.RedisSessionManager" host= "192.168.1.223" <!-- Redis地址 --> port= "6379" <!-- Redis端口 --> paassword= "tomcat" <!-- Redis密码 --> database= "0" <!-- 存储Session的Redis库编号 --> maxInactiveInterval= "60" <!-- Session失效的间隔(秒) --> /> < /Context > mv commons-pool2-2.2.jar jedis-2.7.2.jar tomcat-redis-session-manage-tomcat7.jar /usr/local/tomcat-7 .0.54 /lib/ |
如何测试session会话保持?
可以看到虽然Server从TomcatA变为TomcatB,但session的创建时间没有变化,这就完成了session共享。