本帖最后由 乐橙306 于 2016-7-6 14:48 编辑
- 参考文档
- http://blog.csdn.net/honghailiang888/article/details/51066411
- nginx 解决session共享问题(jvm-route)方式(其实不是真正实现共享,而是分发固定)
- 1.下载安装jvm_route
- 查看附件
- 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 设置:
- ###################sundong.lol###################
- upstream sundong.lol {
- server 192.168.18.84:8804 srun_id=GC1 max_fails=1 fail_timeout=30s;
- server 192.168.18.120:8804 srun_id=GC2 max_fails=1 fail_timeout=30s;
- jvm_route $cookie_JSESSIONID|sessionid reverse;
- 3.tomcat 设置:
- 192.168.18.84设置:
- 修改tomcat/conf/server.xml
- 192.168.18.120设置:
- 修改tomcat/conf/server.xml
- 192.168.18.84 和120 新增 puic.cache.xml
- cache_1192.168.18.130:11211
- 192.168.18.131:11211530001500
- 4.配置完成
- 这个模块通过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不同步问题,但无法解决宕机后会话转移问题。
编辑回复