JBoss bundle和Apache 2.2.x环境下配置mod_proxy
2014-01-06 18:25
567 查看
这篇文章概要介绍了基于mod_proxy, mod_proxy_balance和JBoss的一个基本的负载均衡解决方案。 Mod_proxy支持使用http/https和AJP协议来代理JBoss。这篇文章基于Apache httpd-2.2.x来介绍,如果你使用了更老的httpd版本,请参考Load Balancing
using mod_rewrite and mod_proxy。
从Apache官网上下载最新的Apache 2.2.x安装包并安装。 不需要特殊设置,使用默认设置就可以。 在下面的步骤中,APACHE_HOME指的是Apache服务器的安装目录。
步骤2:配置Apache运行mod_proxy(HTTP)
确保至少下列模块被正确加载(去掉httpd.conf中相关行前面的注释)
在APACHE_HOME/conf/httpd.conf中增加下面几行:(译者注:其实在Include指令指定的配置文件中都可以,不必都在httpd.conf中)
using mod_rewrite and mod_proxy。
配置基于http/https的mod_proxy:
步骤1: 下载Apache 2.2.x WEB服务器从Apache官网上下载最新的Apache 2.2.x安装包并安装。 不需要特殊设置,使用默认设置就可以。 在下面的步骤中,APACHE_HOME指的是Apache服务器的安装目录。
步骤2:配置Apache运行mod_proxy(HTTP)
确保至少下列模块被正确加载(去掉httpd.conf中相关行前面的注释)
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这几个模块对负载均衡功能来说已经足够了。 但是如果你要使用FTP的话,那需要加载mod_proxy_ftp模块,同样,如果要使用SSL的话,需要加载mod_proxy_connect模块。
在APACHE_HOME/conf/httpd.conf中增加下面几行:(译者注:其实在Include指令指定的配置文件中都可以,不必都在httpd.conf中)
<Proxy balancer://mycluster> Order deny,allow Allow from all BalancerMember http://host1:8080 route=node1 BalancerMember http://host2:8180 route=node2 </Proxy> ProxyPass /jmx-console balancer://mycluster ProxyPassReverse /jmx-console http://host1:8080/jmx-console ProxyPassReverse /jmx-console http://host2:8180/jmx-console[/code]默认情况下,负载均衡是按照每个请求的处理方式,也就是基于权重的请求计数,由参数lbmethod控制。 stickysession参数决定了当请求到来时,该使用哪个会话名称或者cookie来进行路由,这个参数没有默认值,因为也需要设置好。ProxyPass /jmx-console balancer://mycluster lbmethod=byrequests stickysession=JSESSIONID|jsessionid你能够在Apache HTTP服务器文档中找到更多关于ProxyPass的说明:http://httpd.apache.org/docs/2.2/mod/mod_proxy.html .
步骤3: 如果需要使用sticky session的话还需要配置JBoss服务器
编辑JBOSS_HOME/server/all/deploy/jbossweb-web.deployer/server.xml 文件, 找到<Engine>标签并增加jvmRoute属性:<Engine name="jboss.web" defaultHost="localhost" jvmRoute="node1"> . </Engine>
步骤4:配置JBoss服务器,添加jvmRoute到会话中
最后,我们需要告诉JBoss服务器添加jvmRoute的值到会话的cookie中,这样mod_proxy_balancer才能够路由收到的请求。
编辑文件JBOSS_HOME/server/all/deploy/jboss-web.deployer/META-INF/jboss-service.xml ,找到名为UseJK的属性,并设置为“true":<attribute name="UseJK">true</attribute>配置基于AJP的mod_proxy:
步骤1:同上
步骤2:设置Apache服务器运行mod_proxy(AJP)
确保至少下列模块被正确加载(去掉httpd.conf中相关行前面的注释)LoadModule proxy_module modules/mod_proxy.so LoadModule proxy_balancer_module modules/mod_proxy_balancer.so LoadModule proxy_ajp_module modules/mod_proxy_ajp.so在APACHE_HOME/conf/httpd.conf中增加下列几行:<Proxy balancer://mycluster> Order deny,allow Allow from all BalancerMember ajp://localhost:8009/jmx-console BalancerMember ajp://localhost:8109/jmx-console </Proxy> ProxyPass /jmx-console balancer://mycluster
步骤3:同上
步骤4:同上何时使用mod_jk,何时使用mod_proxy来实现负载均衡
相比mod_jk 1.x,使用mod_proxy来胚子负载均衡要简单得多
从Apache httpd2.2.2版本开始,mod_proxy已经工作的很好。不要在更早的版本上使用mod_proxy。
mod_jk在持续发展阶段,已经被世界各地的人们广泛尝试和验证。mod_proxy相对来说比较新。(译者注,因为是老文,所以有此说法)
mod_proxy_http不能将SSL信息转发到JBoss服务器(参考Forwarding SSL environment when using http/https proxy
)
mod_proxy允许在Apache服务器和JBoss服务器之间使用https(参考Encrypting connection between httpd and TC)
如果你已经决定使用mod_proxy,有两个选择来实现负载均衡何时使用mod_proxy + mod_proxy_http和mod_proxy + mod_proxy_ajp来实现负载均衡
AJP是二进制的,因此能够节省传输的开销
JBoss服务器处理AJP比处理HTTP更快,更高效
然而,mod_proxy_http现在实现了连接池和负载均衡,因此在下决定之前,你需要验证一下mod_proxy_http和mod_proxy_ajp
这里是mod_proxy_ajp vs mod_jk的FAQ使用sticky sessions:
给ProxyPass添加stickysession参数ProxyPass /jmx-console balancer://mycluster stickysession=JSESSIONID lbmethod=bytraffic nofailover=Offmod_proxy_http和mod_proxy_ajp都支持Sticky Session
注:如果你使用mod_proxy_http,那必须在每一条BalancerMember上都创建一个ProxyPassReverse处理AJP头不能大于8K的限制:
默认的AJP报文头是8K,由于http头只包含在第一个报文中,因此有可能需要克服AJP的这个限制。
通过在<Connector/>标签中增加packetSize参数可以达到这个目的:<Connector port="8009" protocol="AJP/1.3" packetSize="20000" redirectPort="8443" ></Connector>还需要修改httpd.conf中的ProxyIOBufferSize指令。例如:ProxyIOBufferSize 19000 LimitRequestFieldsize 18000packetSize参数从Tomcat 5.5.21和Tomcat 6.0.1开始支持。
老版本的httpd服务器(2.2.5以前)需要打一个补丁来支持此项扩展。补丁位于:http://people.apache.org/~jfclere/patches/ProxyIOBufferSize.patch
文章原文链接:https://community.jboss.org/wiki/UsingModproxyWithJBoss?_sscc=t
相关文章推荐
- windows下配置apache2.2+python2.5+mod_python=Django环境
- Ubantu系统下Apache2.4.7+mod_wsgi+Django环境配置
- Apache2.2+svn1.6.6 windowsxp 下安装配置版本控制的环境
- Linux下配置Apache+Mod_Wsgi+Django环境
- Apache2.2模块mod_proxy和mod_jk比较/区别
- JBoss 系列五十一:使用Apache httpd(mod_proxy)和JBoss构架高可用集群环境
- Apache2.2+svn1.6.6 windowsxp 下安装配置版本控制的环境
- Windows下php5.4+apache2.2+mysql5开发环境配置
- apache+mod_wsgi+django的环境配置
- PHP5.4+Apache2.2的环境配置
- Apache mod_proxy通过https访问后端服务器的配置
- Apache+Tomcat通过ajp_proxy配置php和jsp环境
- php5.3+Apache2.2在win7下环境配置
- windowsXP环境下apache2.2+mysql5.1+php5.2+phpmyadmin2.11配置指引
- 配置Apache2.2+PHP5+CakePHP1.2+MySQL5运行环境
- JSP环境配置 Apache2.2和Tomcat5.5整合
- windows环境下wampserver的配置教程 Apache2.2 Apache2.4.9
- windows2003+apache2.2+python2.7配置django mod_wsgi
- Tomcat+Apache2.2使用mod_proxy做请求转发
- win8下httpd2.2-64bit,mod_wsgi,python2.7 配置运行环境攻略