nginx+tomcat:负载均衡配置(使用粘性session)

jopen 8年前

(1)举个简单的例子,以tomcat为例,我们都知道session存在于服务器端,对于不是分布式部署,整个系统的session都会是这唯一的服务器来管理。这点   没问题。但是对于分布式部署来说,假设有tomcatA与tomcatB,但用户user访问系统时,通过负载均衡,此user访问了位于tomcatA上的应用。系统给此用户分配了一个session来标识用户身份,并返回sessionID给浏览器。这时user又向服务器发送个请求。假设这时候负载均衡到了tomcatB,但是此时tomcatB上并没有存有user相应的session信息。根据一般应用的设置,会提示user重新登录,试想下user就这样一直登录,一直被提示未登录,这样肯定行不通。这就是session保持的问题。

      解决session保持有几种方法,例如nginx自带的ip_hash模块,session复制,以及使用类似redis这种缓存数据库来实现对session的统一管理。在这里介绍的是粘性session;

      

     (2) 粘性session的概念:

                  用户在持续访问系统时,根据粘性session,仍会被分配到上一次访问的服务器中。

     (3)粘性session的配置:

                  1.给nginx添加 nginx_upstream_jvm_route 模块

                        下载: http://down.51cto.com/data/910451

                         安装 : 解压后,首先执行patch -p0 < /nginx_upstream_jvm_route/jvm_route.patch 补丁文件

                                     然后在./configure nginx时,–add-module=/nginx_upstream_jvm_route

                 2.配置nginx.conf

                     

         server 192.168.10.63:8081 srun_id=tomcat0;

            server 192.168.10.63:8088 srun_id=tomcat1;

            jvm_route $cookie_JSESSIONID|sessionid reverse; 

          

                3.配置tomcat

                   在<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat0">处,添加 jvmRoute="tomcat0";


                   注:此处的jvmRoute的值应同nginx.conf中的srun_id的值 相对应。

                 4.重新启动nginx与tomcat,配置完成

  (4)负载均衡优化配置

                

server 192.168.10.63:8081 srun_id=tomcat0 max_fails=3 fail_timeout=60s                                          上面max_fails=3 fail_timeout=15s两个参数代表在15s,若有3次失败连接,则在下个15s内不再访问该服务器。


来自: http://my.oschina.net/u/1864728/blog/595307