JBoss bundle和Apache 2.2.x环境下配置mod_proxy
来源:互联网 发布:凤凰卫视直播软件apk 编辑:程序博客网 时间:2024/04/30 06:34
这篇文章概要介绍了基于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。
配置基于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默认情况下,负载均衡是按照每个请求的处理方式,也就是基于权重的请求计数,由参数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 19000LimitRequestFieldsize 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
- JBoss bundle和Apache 2.2.x环境下配置mod_proxy
- JBoss 系列五十一:使用Apache httpd(mod_proxy)和JBoss构架高可用集群环境
- Windows环境下配置Apache 2.2.x + SSL
- Windows环境下配置Apache 2.2.x + SSL
- Apache配置反向代理、负载均衡和集群(mod_proxy方式)
- Apache配置反向代理、负载均衡和集群(mod_proxy方式)
- Apache配置反向代理、负载均衡和集群(mod_proxy方式)
- Apache配置反向代理、负载均衡和集群(mod_proxy方式)
- Mac OS X 10.5.8环境下配置apache 2.2.13和php5.3和tomcat6.0.26集成
- Linux环境下配置jboss
- Mac下Apache和PHP环境配置
- MAC OS X环境下配置APACHE+PHP+MYSQL+PHPMYADMIN
- tomcat+apache+mod_proxy代理模式配置集群
- 如何使用apache mod_proxy和Tomcat搭建基于SSL的loadbalance集群环境
- Windows环境下配置Apache 2.2.x + SSL ,实现https方式
- Apache和Tomcat组合方式:mod_proxy
- Apache配置反向代理、负载均衡和集群(mod_proxy方式) 经典
- jboss和apache的集群配置
- 环境变量的配置
- 六类qsort排序方法
- XMPP环境搭建常见错误
- sscanf函数与sscanf_s函数
- 安装HBase 0.94.6-cdh4.5.0
- JBoss bundle和Apache 2.2.x环境下配置mod_proxy
- Wi-Fi Display analysis (一)framework
- 自动行号功能实现不同方法研究
- 网址收藏(不断更新中)
- 烫烫烫烫与屯屯屯屯…
- linux下动态库/静态库 链接路径设置问题
- Data compression on Hbase will make your mapreduce job fly
- ACM(004)ASCII码排序(2)
- IT求职整理Ⅲ---常见排序算法小结