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

本文详细介绍了如何利用jvm_route模块在Nginx和Tomcat之间实现Session共享,通过配置示例展示了解决方案的实施步骤,包括Nginx、Tomcat的配置调整及模块安装等关键环节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >



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不同步问题,但无法解决宕机后会话转移问题。


评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值