时间:2021-07-01 10:21:17 帮助过:21人阅读
nginx 解决session共享问题(jvm-route)方式(其实不是真正实现共享,而是分发固定,查看评论2)
1.下载安装jvm_route:http ://nginx-upstream-jvm-route.googlecode.com/svn/trunk/nginx-upstream-jvm-route-read-only
cd /usr/src/nginx-1.2.1
patch - p0 < /usr/local/nginx/nginx_upstream-jvm-route-read-only/jvm_route.patch
./configure --add-module=/usr/local/nginx/nginx-upstream-jvm-route-read-only
make & make install
2.nginx 设置:
修复
upstream www.linuxidc.com {
server 192.168.1.116:8080 srun_id=a;
这里 srun_id=a 对应的是 server1 resin 配置里的 server id="a"
server 192.168.1.117:8081 srun_id=b;
这里 srun_id=b 对应的是 server2 resin 配置里的 server id="b"
jvm_route $cookie_JSESSIONID|sessionid;
}
3.tomcat 设置:
192.168.0.116设置:
修改tomcat/conf/server.xml
192.168.0.117设置:
修改tomcat/conf/server.xml
3.配置完成
这个模块通过session cookie的方式来获取session粘性。如果在cookie和url中并没有session,则这只是个简单的round-robin 负载均衡。
jvm_route的原理(from 作者 Weibin Yao):
1. 一开始请求过来,没有带session信息,jvm_route就根据round robin的方法,发到一台tomcat上面。
2. tomcat添加上session 信息,并返回给客户。
3. 用户再此请求,jvm_route看到session中有后端服务器的名称,它就把请求转到对应的服务器上。
暂时jvm_route模块还不支持默认fair的模式。jvm_route的工作模式和fair是冲突的。对于某个特定用户,当一直为他服务的tomcat宕机后,默认情况下它会重试max_fails的次数,如果还是失败,就重新启用round robin的方式,而这种情况下就会导致用户的session丢失。
总的说来,jvm_route是通过session_cookie这种方式来实现session粘性,将特定会话附属到特定tomcat上,从而解决session不同步问题,但无法解决宕机后会话转移问题。
以上就介绍了nginx 解决session共享问题jvm-route方式(其实没有真正解决共享问题),包括了Session,route方面的内容,希望对PHP教程有兴趣的朋友有所帮助。