Apache :apache_2.0.55 1 ?/p>
Tomcat: apache-tomcat-5.5.17 (zip? 2?/p>
mod_jk:: mod_jk-apache-2.0.55.so 1?/p>
W一部分Q负载均?/strong>
负蝲均衡Q就是apache客戯求均衡的分给tomcat1,tomcat2....d?/p>
1.安装apche,tomcat
http://httpd.apache.org/ 下蝲Apache 2.0.55
http://tomcat.apache.org/download-55.cgi 下蝲tomcat5.5 zip版本Q解压即可,l色版)
http://apache.justdn.org/tomcat/tomcat-connectors/jk/binaries/win32/jk-1.2.15/ 下蝲mod_jk,注意?nbsp; apache版本匚w
按照jdk,我的路径?E:\ide\apache\Apache2
解压两䆾Tomcat, 路径分别?E:\ide\tomcat1,E:\ide\tomcat2
下蝲mod_jk
2.修改Apache配置文ghttp.conf
在apache安装目录下conf目录中找到http.conf
在文件最后加上下面一句话可以了
include "E:\ide\apache\Apache2\conf\mod_jk.conf"
集群有别于分布式的解x案,它采用的是每台服务器q行相同应用的策略,p责^衡的服务器进行分,q对提高整个pȝ的ƈ发量及吞吐量是更有效的办法。而集对h的处理又有两U不同的方式Q负载^衡、状态复?即集?Q状态复刉要在各服务器间复制应用状态,而负载^衡则不用Q每台服务器都是独立的。实践证明,在各应用服务器之间不需要状态复制的情况下,负蝲q可以辑ֈ性能的线性增长及更高的ƈ发需求?/p>
对于集群的其它基知识Q在此就不再做篏赘。以下就q次Apache + JK + Tomcat的负载^衡配|进行ȝQ重点关注整个配|及注意事项?/p>
1?nbsp;Tomcat或JBossQ本文档中采用的是JBoss
2?nbsp;apache
3?nbsp;mod_jk-
使用mod_jk默认的以轮@方式q行q负蝲Q假设有四个服务器节点,?0个请求,则四个节点分别接受请求编号如下:
节点1 |
节点2 |
节点3 |
节点4 |
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
|
|
而集方式也是用这U方法进行^衡。Tomcat中的集群原理是通过l播的方式进行节点的查找q用TCPq接q行会话的复制?/p>
集群不同于负载^衡的是,׃集群服务需要在处理h之间不断地进行会话复Ӟ复制后的会话会慢慢变得庞大Q因此它的资源占用率是非帔R的,如果在ƈ发量大的应用中,复制的会话大会变得相当大,而用的d存更是会q速升高?/p>
但集的会话复制Q增加了pȝ的高可用性。由于在每台服务器都保存有用LSession信息Q如果服务器中某台当机Q应用可以自动切换到其它服务器上l箋q行Q而用L信息不会丢失Q这提高了应用的冗错性?/p>
具体采用负蝲qq是集群Q这要看应用的需求了?/p>
1、下载Apache的安装程序apache_
2、安装完毕后Q将下蝲的mod_jk-
3、然后进入Apache安装目录下的conf子目录中Q打开httpd.conf配置文gQ在最后插入以下一行:
Include conf/mod_jk.conf
4?nbsp;在conf子目录下Q徏立一个新的配|文Ӟmod_jk.confQ此文g为Apache加蝲q接器的配置文gQ文件名可修改,但要与httpd.conf中Include的文件名一_内容如下Q?/p>
# Load mod_jk module. Specify the filename
# of the mod_jk lib you’ve downloaded and
# installed in the previous section
#加蝲mod_jk模块
LoadModule jk_module modules/mod_jk-
# Where to find workers.properties
JkWorkersFile conf/workers2.properties
# Where to put jk logs
JkLogFile logs/mod_jk.log
# Set the jk log level [debug/error/info]
JkLogLevel info
# Select the log format
JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "
# JkOptions indicate to send SSL KEY SIZE,
JkOptions +ForwardKeySize +ForwardURICompat -ForwardDirectories
# JkRequestLogFormat set the request format
JkRequestLogFormat "%w %V %T"
# h分发配置Q可以配|多?/p>
JkMount /* loadbalancer
#xLLookupQ如果ؓonQ很影响性能Q可以有10多秒钟的延迟?br>HostnameLookups Off
注:蓝色加粗的两行是重点Q第一句是Apache加蝲JK模块用的Q第二句为配|哪些URLh由负蝲q器来处理?/p>
5?nbsp;在conf子目录下Q徏立一个新的配|文Ӟworkers2.propertiesQ此文g载^衡的配置文gQ文件名不能修改Q这是JK默认的名字,内容如下Q?/p>
worker.list=loadbalancer
# Define the first node...
worker.server99.port=8009
worker.server99.host=192.168.11.99
worker.server99.type=ajp13
worker.server99.lbfactor=1
worker.server99.local_worker=1
worker.server99.cachesize=1000
worker.server99.cache_timeout=600
worker.server99.socket_keepalive=1
worker.server99.socket_timeout=0
worker.server99.reclycle_timeout=300
worker.server99.retries=3
# Define the second node...
worker.server202.port=8009
worker.server202.host=192.168.11.202
worker.server202.type=ajp13
worker.server202.lbfactor=1
worker.server202.local_worker=1
worker.server202.cachesize=1000
worker.server202.cache_timeout=600
worker.server202.socket_keepalive=1
worker.server202.socket_timeout=0
worker.server202.reclycle_timeout=300
worker.server202.retries=3
# Now we define the load-balancing behaviour
worker.loadbalancer.type=lb
worker.retries=3
worker.loadbalancer.balance_workers=server99 ,server202
worker.loadbalancer.sticky_session=true
worker.loadbalancer.sticky_session_force=true
注:以上定义了两个workerQ一个ؓserver99Q另一个ؓserver202Q定义了一个负载^衡服务器loadbalancerQ其中标蓝色的ؓ重点配置,相关的详l说明可以看官方的网站文档:http://tomcat.apache.org/connectors-doc/Q其它节点的定义可以直接CopyQ修改一下节点名及IP好了?br>A、worker.list=loadbalancer
讑֮工作的负载^衡器Q各Tomcat节点不能加入此列表?/p>
B、worker.server99.lbfactor
负蝲q的权重比Q如果此权重比越大,则分配到此节点的h多Q如以上两个节点的权重比?:1Q则为^均分配?/p>
C、worker.loadbalancer.balance_workers=server99,server202
指定此负载^衡器负责的Tomcat应用节点?/p>
D、worker.loadbalancer.sticky_session=true
此处指定集群是否需要会话复Ӟ如果设ؓtrueQ则表明Z话粘性,不进行会话复Ӟ当某用户的请求第一ơ分发到哪台Tomcat后,后的请求会一直分发到此Tomcat服务器上处理Q如果设为falseQ则表明需求会话复制?/p>
E、worker.loadbalancer.sticky_session_force=true
如果上面的sticky_session设ؓtrueӞ此处也设为trueQ此参数表明如果集群中某台Tomcat服务器在多次h没有响应后,是否当前的hQ{发到其它Tomcat服务器上处理Q此参数在sticky_session=trueӞ影响比较大,会导致{发到其它Tomcat服务器上的请求,找不到原来的sessionQ所以如果此时请求中有读取session中某些信息的话,׃D应用的null异常?/p>
6、Apache服务器的配置文ghttpd.conf中,默认有三个参数对性能的媄响比较大Q但Ҏ不同的性能要求Q参数的表现又不一P太小q发提不上去Q太大性能反而不好,Ҏ目的需要,实际做个试Q如q发要求800的话Q可以设定ؓQ?/p>
#一个连接的最大请求数?/p>
MaxKeepAliveRequests 1000Qgؓ0Q则不限制数量)
#每个q程的线E数Q最?920。NT只启动父子两个进E,不能讄启动多个q程
ThreadsPerChild 1000Q最大ؓ1920Q?/p>
#每个子进E能够处理的最大请求数
MaxRequestsPerChild 1000Qgؓ0Q则不限制数量)
q三个参数要Ҏ不同的需求,不同的服务器q行调整?/p>
1、对于Tomcat或JBoss的安装,q里不做说明Q目前我们是采用Apache+JBossQ不q,JBoss也是用的TomcatQ所以这里的配置也是适合Tomcat的;
2、对于JBoss的配|,很简单,只需要改两个地方可以了Q?/p>
W一个地方:q入jboss-
W二个地方:q入jboss-
q里有一个需要特别注意的地方QJBoss的Tomcat中,关于AJPq接协议的默认配|,对于大ƈ发量是不够用的,要做一些修改,q入jboss-
emptySessionPath="true" enableLookups="false" redirectPort="8443"
protocol="AJP/1.3" maxThreads="3000"/>
maxThreads的D看你的ƈ发量多大Q设|太大也不好?/p>
xQ整个配|全部完成,注意一ҎQ在各JBoss节点Q重启或新增加一个JBoss节点Ӟ需要重新启动ApacheQ而对于服务器中某个JBoss节点shutdownQApache会自动侦,不用重新启动?/p>
如果在运行过E中Q群中的某个JBoss节点shutdownQ则已登录到此服务器上的用户的请求将出错Q此服务器负责的session丢失,但Apache会自动侦到此服务器已shutdownQ后l的新请求将不会再引导到此节炏V?/p>
对于负责h分发的Apache服务器,需要消耗大量的CPU资源Q因此如果在试q程中出C些Service Temporarily Unavailable或Server has shut down the connection prematurelyq样的错误,q一般都是服务器配置不够好引LQ或者是Apache、Tomcat、及应用中的某些配置不够使用Q这时候就要考虑换更好的机器或优化应用中的配|?/p>
常见问题
一、cannot connect to serverQ无法连接到服务器。这U情冉|服务器的配置有问题,服务器无法承受过多的q发q接了,需要优化服务器的配|:
如操作系l采用更高版本,如windows 2003 serverQ?/p>
优化tomcat配置QmaxThreads="500" minSpareThreads="400" maxSpareThreads="450"
但是tomcat 最多支?00个ƈ发访?/p>
优化apache配置Q?/p>
ThreadsPerChild 1900
MaxRequestsPerChild 10000
二?nbsp;Action.c(10): Error -27791: Server has shut down the connection prematurely
HTTP Status-Code=503 (Service Temporarily Unavailable)
一般都是由于服务器配置不够好引LQ需要优化硬件和调整E序了?/p>
三、无法处理请求:
当我们输?nbsp;***.do 命o后,apache却返回错误信息,而连接tomcat却没有问题。原因是没有?do命o转发ltomcat处理。解x法如下:
在apache配置文g中配|如下内容:
JkMount /*.jsp loadbalancer
JkMount /*.do loadbalancer