征服 Nginx + Tomcat

2年前一直折腾Apache,现如今更习惯Nginx。 :D 搭建网站又遇到2年前遇到的问题——Session同步。 :) (参考我以前的帖子——[url=http://snowolf.iteye.com/blog/743611]征服 Apache + Tomcat[/url])只不过现今担当负载均衡的Apache换成了Nginx! :)
今天简要说明一下Nginx+Tomcat负载均衡实现,[b]重点介绍Nginx+Tomcat+Session共享实现[/b]。

[b]
相关内容:
[url=http://snowolf.iteye.com/blog/739475]征服 Apache + SSL[/url]
[url=http://snowolf.iteye.com/blog/740347]征服 Apache + SVN[/url]
[url=http://snowolf.iteye.com/blog/892001]征服 Apache + SVN + LDAP[/url]
[url=http://snowolf.iteye.com/blog/743611]征服 Apache + Tomcat[/url]
[url=http://snowolf.iteye.com/blog/1497929]征服 Nginx[/url]
[url=http://snowolf.iteye.com/blog/1539932]征服 Nginx + Tomcat[/url]
[/b]

Nginx负载均衡,其实主要就是用upstream、server指令,再配以权重等等参数。如果为了让nginx支持session共享,还需要额外增加一个模块。

[size=large][b]一、Nginx负载均衡[/b][/size]
在http{...}中配置一个upstream{...},参考如下:
[quote]
upstream tomcat {
server 10.11.155.26:8080;
server 10.11.155.41:8080;
}
[/quote]
接着修改location节点,配置代理:
[quote]location / {
...
proxy_pass http://tomcat;

...
}[/quote]
当访问根路径时,会轮播路由到两台服务器上,至于后端服务器是tomcat还是jetty之类的,都无所谓,照葫芦画瓢就是了。 :D
当然,有的机器性能好,或者负载低,可以承担高负荷访问量,可以通过权重(weight),提升访问频率。数值越高,被分配到的请求数越多。
server指令参数如下:
[list]
[*]weight——权重,数值越大,分得的请求数就越多,默认值为1。
[*]max_fails——对访问失败的后端服务器尝试访问的次数。默认值为1,当设置为0时将关闭检查。
[*]fail_timeout——失效超时时间,当多次访问失败后,对该节点暂停访问。
[*]down——标记服务器为永久离线状态,用于ip_hash指令。
[*]backup——仅当非backup服务器全部宕机或繁忙时启用。
[/list]
例如,可以这样配置:
[quote]
upstream tomcat {
server 10.11.155.26:8080 weight=5;
server 10.11.155.41:8080 weight=10;
}
[/quote]
后者分得的请求数就会较高。

[size=large][b]二、Nginx+Tomcat+Session共享[/b][/size]
为了让Nginx支持Tomcat的Session共享,需要对其升级,增加jvmroute模块。

[b]1.下载[url=http://code.google.com/p/nginx-upstream-jvm-route/]nginx-upstream-jvm-route[/url]组件、对nginx源码做补丁。[/b]
我把nginx-upstream-jvm-route下载到了/opt/software路径下。
先切换到nginx源码目录下,执行:
patch -p0 < /opt/software/nginx_upstream_jvm_route/jvm_route.patch

[quote]patching file src/http/ngx_http_upstream.c
Hunk #1 succeeded at 4095 (offset 358 lines).
Hunk #3 succeeded at 4227 (offset 358 lines).
Hunk #5 succeeded at 4326 (offset 358 lines).
patching file src/http/ngx_http_upstream.h
Hunk #1 succeeded at 90 (offset 5 lines).
Hunk #3 succeeded at 118 (offset 5 lines).[/quote]
说明补丁做好了! :D

[b]2.升级nginx[/b]
先别急着折腾nginx-upstream-jvm-route,先看看nginx当时安装时的参数:
nginx -V

[quote]nginx version: nginx/1.2.0
configure arguments: --prefix=/opt/servers/nginx --user=nginx --group=www --pid-path=/var/run/nginx.pid --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --with-pcre=/opt/software/pcre-8.10 --with-zlib=/opt/software/zlib-1.2.5 --with-http_stub_status_module --with-http_realip_module --with-http_gzip_static_module[/quote]
记得先备份nginx.conf! :x
使用追加参数(--add-module),增设nginx-upstream-jvm-route模块,[b]--add-module=/opt/software/nginx_upstream_jvm_route[/b],编译安装。
./configure --prefix=/opt/servers/nginx --user=nginx --group=www --pid-path=/var/run/nginx.pid --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --with-pcre=/opt/software/pcre-8.10 --with-zlib=/opt/software/zlib-1.2.5 --with-http_stub_status_module --with-http_realip_module --with-http_gzip_static_module --add-module=/opt/software/nginx_upstream_jvm_route && make && make insatll

如果没有错误提示,nginx就成功升级了! :D

[b]3.修改upstream配置[/b]
要让Nginx支持Tomcat的jvmRoute,并共享session,在upstream下作如下修改:
[quote]
upstream tomcat {
server 10.11.155.26:8080 srun_id=tomcat1;
server 10.11.155.41:8080 srun_id=tomcat2;

jvm_route $cookie_JSESSIONID|sessionid reverse;
}
[/quote]
[b]srun_id[/b]跟tomcat配置有关。

[b]4.Tomcat集群配置(Tomcat6、7通用)[/b]
该配置参考[url=http://snowolf.iteye.com/blog/743611]征服 Apache + Tomcat[/url],以下仅作简要说明。
a.修改server.xml
找到[b]Engine[/b]节点,并设置[b]jvmRoute[/b],这里指定[b]tomcat1[/b]。
<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1">

可以直接粘贴以下代码,并对应修改[b]Receiver[/b]节点中的[b]address[/b]属性,指向本机:

<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"
channelSendOptions="8">
<Manager className="org.apache.catalina.ha.session.DeltaManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"/>
<Channel className="org.apache.catalina.tribes.group.GroupChannel">
<Membership className="org.apache.catalina.tribes.membership.McastService"
address="224.0.0.0"
port="45564"
frequency="500"
dropTime="3000"/>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="10.11.155.26"
port="4000"
autoBind="100"
selectorTimeout="5000"
maxThreads="6"/>
<Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
<Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
</Sender>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>
</Channel>
<Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
filter=".*\.gif;.*\.js;.*\.jpg;.*\.png;.*\.htm;.*\.html;.*\.css;.*\.txt;"/>
<Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>
<ClusterListener className="org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener"/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>

[color=red]注:如果本机上有多个tomcat并存,[b]Receiver[/b]节点中的[b]port[/b]属性,使其绑定在不同的端口上。[/color]
[b]Membership[/b]节点[b]address[/b]属性配置多播地址,可使用[b]route[/b]命令将其打开,参考如下:
route add -net 224.0.0.0/8 dev eth0 

b.修改应用的[b]web.xml[/b]
在web.xml末尾增加[b]<distributable />[/b]
<web-app>
...
<distributable />
</web-app>


至此,已完成所有配置,重启tomcat、nginx,访问服务测试页面(见附件),强行关闭其中一台tomcat,令请求转向另一个台tomcat,测试session是否同步:
[img]http://dl.iteye.com/upload/attachment/0068/5945/49112793-baa6-323e-9c92-0727261d41e5.jpg[/img]
session共享成功,非粘性实现。 :D

[b]
相关内容:
[url=http://snowolf.iteye.com/blog/739475]征服 Apache + SSL[/url]
[url=http://snowolf.iteye.com/blog/740347]征服 Apache + SVN[/url]
[url=http://snowolf.iteye.com/blog/892001]征服 Apache + SVN + LDAP[/url]
[url=http://snowolf.iteye.com/blog/743611]征服 Apache + Tomcat[/url]
[url=http://snowolf.iteye.com/blog/1497929]征服 Nginx[/url]
[url=http://snowolf.iteye.com/blog/1539932]征服 Nginx + Tomcat[/url]
[/b]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值