欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

nginx 解决session共享问题jvm-route方式(其实没有真正解决共享问题) defroute icroute airlinerout

程序员文章站 2022-06-07 17:30:12
...


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

./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教程有兴趣的朋友有所帮助。

相关标签: Session route