`
hanqunfeng
  • 浏览: 1541260 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Nginx:session与nginx_upstream_jvm_route

 
阅读更多

 

1)ip_hash(不推荐使用)

 nginx中的ip_hash技术能够将某个ip的请求定向到同一台后端,这样一来这个ip下的某个客户端和某个后端就能建立起稳固的session,ip_hash是在upstream配置中定义的: 

 

upstream backend { 
    server 127.0.0.1:8080 ; 
    server 127.0.0.1:9090 ; 
    ip_hash; 
    } 

 不推荐使用的原因如下:

 

  1/ nginx不是最前端的服务器。

   ip_hash要求nginx一定是最前端的服务器,否则nginx得不到正确ip,就不能根据ip作hash。譬如使用的是squid为最前端,那么nginx取ip时只能得到squid的服务器ip地址,用这个地址来作分流是肯定错乱的。 

    2/ nginx的后端还有其它方式的负载均衡。

   假如nginx后端又有其它负载均衡,将请求又通过另外的方式分流了,那么某个客户端的请求肯定不能定位到同一台session应用服务器上。

   3/ 多个外网出口。

    很多公司上网有多个出口,多个ip地址,用户访问互联网时候自动切换ip。而且这种情况不在少数。使用 ip_hash 的话对这种情况的用户无效,无法将某个用户绑定在固定的tomcat上 。

 

2)nginx_upstream_jvm_route(nginx扩展,推荐使用)

nginx_upstream_jvm_route 是一个nginx的扩展模块,用来实现基于 Cookie 的 Session Sticky 的功能。

简单来说,它是基于cookie中的JSESSIONID来决定将请求发送给后端的哪个server,nginx_upstream_jvm_route会在用户第一次请求后端server时,将响应的server标识绑定到cookie中的JSESSIONID中,从而当用户发起下一次请求时,nginx会根据JSESSIONID来决定由哪个后端server来处理。

 

1/ nginx_upstream_jvm_route安装

下载地址(svn):http://nginx-upstream-jvm-route.googlecode.com/svn/trunk/

假设nginx_upstream_jvm_route下载后的路径为/usr/local/nginx_upstream_jvm_route,

(1)进入nginx源码路径

patch -p0 < /usr/local/nginx_upstream_jvm_route/jvm_route.patch

(2)./configure  --with-http_stub_status_module --with-http_ssl_module --prefix=/usr/local/nginx --with-pcre=/usr/local/pcre-8.33 --add-module=/usr/local/nginx_upstream_jvm_route

(3)make & make install

关于nginx的下载与安装参考:http://hanqunfeng.iteye.com/blog/697696

 

2/ nginx配置

upstream  tomcats_jvm_route
        {
             # ip_hash; 
              server   192.168.33.10:8090 srun_id=tomcat01; 
              server   192.168.33.11:8090 srun_id=tomcat02;
              jvm_route $cookie_JSESSIONID|sessionid reverse;
        }

 3/ tomcat配置

修改192.168.33.10:8090tomcat的server.xml,

将
<Engine name="Catalina" defaultHost="localhost" >
修改为:
<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat01">

 同理,在192.168.33.11:8090server.xml中增加jvmRoute="tomcat02"。

4/ 测试

启动tomcat和nginx,访问nginx代理,使用Google浏览器,F12,查看cookie中的JSESSIONID,

形如:ABCD123456OIUH897SDFSDF.tomcat01 ,刷新也不会变化

 

 

分享到:
评论
10 楼 java-lxm 2015-10-16  
其中一台tomcat  down掉后就无法访问了,怎么解决
9 楼 premier815 2015-07-19  
mengqingyu 写道
nginx 1.7版 和 nginx_upstream_jvm_route 整合貌似有问题,patch找不到文件,难道只支持老版本?


https://github.com/nulab/nginx-upstream-jvm-route
这个可以使用
8 楼 mengqingyu 2015-03-15  
nginx 1.7版 和 nginx_upstream_jvm_route 整合貌似有问题,patch找不到文件,难道只支持老版本?
7 楼 qunice 2014-11-20  
这样是不行的!
6 楼 myprincejava 2014-10-16  
我明白了,这个不是支持window的。
5 楼 myprincejava 2014-10-16  
我想问问博主,srun_id=tomcat01 这个配置,我怎么启动nginx报srun_id 无效?是什么意思?
4 楼 zhouxiaozhxi 2014-05-15  
我想问问,nginx_upstream_jvm_route与nginx_sticky_module是什么关系
3 楼 jay1818 2013-12-24  
我想问问,nginx_upstream_jvm_route和weblogic怎么配置
2 楼 hanqunfeng 2013-12-20  
glutton3 写道
您好,我想问问,nginx_upstream_jvm_route是专门给tomcat用的么?jboss不可以使用?


只是拿tomcat举例,jboss同样支持的。
1 楼 glutton3 2013-12-19  
您好,我想问问,nginx_upstream_jvm_route是专门给tomcat用的么?jboss不可以使用?

相关推荐

    linux nginx nginx_upstream_jvm_route

    linux nginx nginx_upstream_jvm_route

    nginx-upstream-jvm-route-1.15

    【标题】"nginx-upstream-jvm-route-1.15" 涉及的核心知识点是Nginx的upstream模块与JVM路由的整合,特别针对Nginx 1.15版本。这个项目旨在解决在配置Nginx时遇到的特定错误提示“nginx: [emerg] invalid parameter ...

    nginx-upstream-jvm-route 和 nginx 对应版本,亲测可用

    此资源有两个文件,含 nginx-upstream-jvm-route 和 nginx 对应版本,都是tar.gz文件。 安装方法网上很多就不写了,亲测可用。 不用担心版本不匹配造成安装失败,再浪费积分去到处下载尝试的烦恼。 此资源有两个文件...

    nginx-upstream-jvm-route-1.6.tar.gz

    nginx_upstream_jvm_route 是一个 Nginx 的扩展模块,用来实现基于 Cookie 的 Session Sticky 的功能。 安装方法(进入Nginx源码目录): #patch -p0 &lt; /path/to/this/directory/jvm_route.patch # ./configure -...

    nginx-upstream-jvm-route nginx共享Session

    标题 "nginx-upstream-jvm-route nginx共享Session" 涉及到的是在使用Nginx作为反向代理服务器时,如何实现多个Java应用服务器(通常指的是JVM实例)之间的Session共享。这通常在构建高可用性和负载均衡的Web服务...

    nginx-upstream-jvm-route-1.12.0.tar.gz

    nginx_upstream_jvm_route 是一个 Nginx 的扩展模块,用来实现基于 Cookie 的 Session Sticky 的功能。 安装方法(进入Nginx源码目录): #patch -p0 &lt; /path/to/this/directory/jvm_route.patch # ./configure -...

    nginx-upstream-jvm-route-0.1.tar.gz

    在解压后的"nginx_upstream_jvm_route"目录中,我们可以找到Nginx的配置示例、Java应用程序的部署配置以及可能的脚本文件。这些资源可以帮助我们配置Nginx以识别和利用JVM Route,确保Session数据在Tomcat集群中的...

    linux下为nginx添加jvmroute模块的方法

    代码如下:cd /optwget ... /opt/nginx_upstream_jvm_route/jvm_route.patc

    从零开始的Nginx详解(5)【Nginx-负载均衡】

    测试三、Nginx负载均衡算法四、Nginx相关文章链接 演示环境: 系统版本:CentOS Linux release 7.7.1908 (Core) nginx版本:nginx/1.16.1 当然讲解还是官方最棒:英语和俄语大佬请点击这里移步官网 一、负载均衡...

    Nginx + Tomcat +session共享.docx

    patch -p0 &lt; /opt/software/nginx_upstream_jvm_route/jvm_route.patch ``` 如果成功,你会看到类似 "Hunk #x succeeded" 的输出。 3. 记录下 Nginx 的原始配置参数,通常可以通过 `nginx -V` 查看。 4. 备份 ...

    nginx tomcat集群 session复制

    - 配置Nginx-upstream-jvm-route模块,使Nginx能够根据Session ID选择正确的Tomcat实例。 ### 五、Session复制策略 - **粘滞会话(Sticky Sessions)**:Nginx将用户的请求转发到上次处理该会话的Tomcat实例,以...

    nginx-upstream-manager.zip

    `nginx-upstream-manager.zip` 提供了一个开源项目,用于更方便地管理和操作 Nginx 的 upstream 配置。 这个项目的核心是 `upstream_manager.py` 脚本,它提供了对 Nginx upstream 集群进行增删改查等操作的能力。...

    linux环境下通过nginx实现tomcat集群.pdf

    - `patch -p0 ${nginx-upstream-jvm-route解压目录}/jvm_route.patch` 5. 配置并编译Nginx: - `./configure --prefix=/usr/local/nginx --with-pcre=${pcre解压目录} --with-...

    linux安装nginx和tomcat

    patch -p0 &lt; ../nginx-upstream-jvm-route.tar.gz/jvm_route.patch useradd www ./configure --user=www --group=www --prefix=/usr/local/nginx --with-...

    linux环境下通过nginx实现tomcat集群借鉴.pdf

    这里的`jvm_route`指令使用了$cookie_JSESSIONID|sessionid,这意味着Nginx会根据客户端发送的JSESSIONID Cookie值来决定将请求路由到哪个Tomcat实例,从而实现Session Sticky。 5. 启动Nginx和Tomcat服务: 启动...

    Nginx安装配置、Resin安装配置说明文档

    a)在server1 上安装配置 nginx + nginx_upstream_jvm_route - 22 - b)分别在两台机器上 安装 resin - 22 - c)配置两台机器 的 resin - 23 - d)整合 ngxin resin - 24 - e)测试,打开浏览器,输入 ...

    Web服务器三剑客运维配置实战 Nginx+JVM+Tomcat+HTTP协议.zip

    课程内容包括了Nginx进阶基础,Nginx配置提升,JVM虚拟机尝试,JVM运维实用排障工具,JVM监控工具,Tomcat配置,Tomcat运维与部署等Web服务器的必备运维部署技术。 ===============课程目录=============== (1)\...

    nginx 升级为最新版 1.12.0

    如果你看到的是"nginx-upstream-jvm-route-master"这个文件名,这可能是指Nginx的一个特定模块或插件,用于实现与JVM应用服务器的智能路由。这个插件可能涉及负载均衡、故障转移和动态配置更新等功能。在升级Nginx后...

Global site tag (gtag.js) - Google Analytics