您的位置:首页 > 运维架构 > Nginx

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

2016-04-05 17:23 405 查看

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

 <Engine name="Catalina" defaultHost="localhost" jvmRoute="a">

 192.168.0.117设置:

 修改tomcat/conf/server.xml

 <Engine name="Catalina" defaultHost="localhost" jvmRoute="b">

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不同步问题,但无法解决宕机后会话转移问题。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  session nginx 共享