Apache+Jetty负载均衡配置
Apache和jetty组合使用有三种方式:
1、 使用Apache mod_proxy和一个普通的Jetty HTTP连接器。
2、 使用Apache mod_proxy_ajp和Jetty AJP连接器。
3、 使用Apache mod_jk和Jetty AJP连接器。
其中,Jetty推荐使用第一种。推荐理由如下:
1、 使用HTTP,Jetty的性能更好。
2、 AJP协议文档缺乏,且许多版本是违规的。
如果要使用AJP,mod_proxy_ajp优于mod_jk。以前,mod_jk的负载均衡能力使得你必须使用它,但是在Apache2.2,mod_proxy_balancer可用,胜于HTTP和AJP连接器。
使用mod_proxy,实际上是配置反向代理,它只是简单的将请求访问的URL转发到jetty,如果要实现负载均衡,apache还需要加载mod_blancer。
1、 下载Apache
http://de.apachehaus.com/downloads/,本例版本为httpd-2.2.29-x64
2、 下载Jetty,版本为jetty-8.1.14。
3、 配置Apache 的httpd.conf,在其中增加如下的modules
LoadModule proxy_module /modules/mod_proxy.so
LoadModule proxy_balancer_module /modules/mod_proxy_balancer.so
LoadModule proxy_http_module /modules/mod_proxy_http.so
LoadModule proxy_ajp_module /modules/mod_proxy_ajp.so
LoadModule jk_module /modules/mod_jk.so
在httpd.conf文件末尾增加反向代理配置,
ProxyRequests Off
<Proxy *>
Order deny,allow
Allow from all
</Proxy>
ProxyPass /za http://localhost:8080/
ProxyPass / http://localhost:8080/
Apache默认配置的是80端口,当访问http://localhost或者http://localhost/za时,请求应转发到jetty,就是http://localhost:8080。
配置完成后,启动Apache,然后访问http://localhost,访问的是jetty页面。
4、 负载均衡配置
如果要配置负载均衡,假设本机有两个jetty实例,监听端口分别是8080,8090。则简单的负载均衡配置如下:
ProxyRequests Off
<Proxy *>
Order deny,allow
Allow from all
</Proxy>
ProxyPass /zk balancer://mycluster
ProxyPass /zk balancer://mycluster
<Proxy balancer://mycluster>
BalancerMember http://localhost:8109/aa
BalancerMember http://localhost:8108/aa
</Proxy>