Bootstrap

Nginx+Tomcat负载均衡Session复制解决方案

办法有很多,不做程序改动的话,以下是四种解决办法:

1. 使用tomcat自带的cluster方式,多个tomcat间自动实时复制session信息,配置简单。但效率较低,在大并发下表现并不好

2. 利用nginx的基于访问ip的hash路由策略,保证访问的ip始终被路由到同一个tomcat上,这个配置更简单。但是我们的应用很可能是某一个局域网大量用户同时登录,这样负载均衡就没作用了

3. 利用memcached把多个tomcat的session集中管理,这是最直接的解决方案,但是操作起来也最为复杂

4.利用nginx + nginx-upstream-jvm-route 模块来实现session的负载均衡

 

本文只做第四种方式的介绍:

1.打开http://code.google.com/p/nginx-upstream-jvm-route/(nginx-upstream-jvm-route首页),如下:

 

2.点击Wiki标签页,可以看到有各个版本服务器的配置

 

3.点击nginx_with_tomcat,查看tomcat的配置:

 

下载后在压缩包中有个README,说明了安装方法(PS.只有Linux版,window建议使用Apache)

 

OVER!

 

 

;