apache+jkmount+tomcat

原文: http://www.blogjava.net/zolly/articles/Apache_tomcat_loadbalance.html
一部分、非集群:(集群见下部分)
1、  Tomcat5.5.17,下载地址: http://www.apache.org/dist/tomcat/tomcat-5/v5.5.17/bin/
2、  Apache2.2.3,下载地址: http://apache.justdn.org/httpd/binaries/win32/apache_2.2.3-win32-x86-no_ssl.msi  ;
3、  mod_jk-1.2.20-apache-2.2.3.so模块,,下载地址: http://www.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/win32/jk-1.2.20/
4、 安装完毕后,将下载的 mod_jk-1.2.20-apache-2.2.3.so改名为mod_jk.so并  复制到 Apache  安装目录下的 modules  子目录中
5、在conf子目录下,建立一个新的配置文件:workers.properties,此文件为负载平衡的配置文件,文件名不能修改,这是JK默认的名字,内容如下:

#ng a worker named worker1 and of type ajp13 worker.list=worker1,worker2 # Set properties for worker1 worker.worker1.type=ajp13 worker.worker1.host=192.168.3.33 worker.worker1.port=8019 worker.worker1.lbfactor=50 #worker.worker1.cachesize=10 #worker.worker1.cache_timeout=600 worker.worker1.socket_keepalive=1 worker.worker1.socket_timeout=300 worker.worker1.connection_pool_size=1000 worker.worker1.connection_pool_timeout=600 # Set properties for worker2 worker.worker2.type=ajp13 worker.worker2.host=192.168.3.33 worker.worker2.port=8009 worker.worker2.lbfactor=50 worker.worker2.socket_keepalive=1 worker.worker2.socket_timeout=300 worker.worker2.connection_pool_size=1000 worker.worker2.connection_pool_timeout=600


6、在 conf 子目录下,建立一个新的配置文件: mod_jk.conf ,此文件为 Apache 加载连接器的配置文件,文件名可修改,但要与 httpd.conf 中 Include 的文件名一致,在logs子目录下建立日志文件mod_jk.log,mod_jk.conf内容如下:

# show the position of workers.properties work file of mod_jk moduler JkWorkersFile conf/workers.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" # show the request be done by tomcat


7、 然后进入 Apache  安装目录下的 conf  子目录中,打开 httpd.conf  配置文件,在最后插入以下一行:  Include conf/mod_jk.conf
以上jkmount配置完毕,接下来apache映射tomcat。是将tomcat指向某一文件夹,部署工程,具体方法见博客关于tomcat部署多应用,类似。
在extra/httpd-vhost.conf加入

Listen 8040 <VirtualHost *:8040> ServerAdmin webmaster@test.com ServerName test.com DocumentRoot /opt/apache2.4/htdocs/test (tomcat也指向次目录,部署应用,以下类似) JkMount /*.jsp worker1 JkMount /*.do worker1 JkMount /search worker1 </VirtualHost> Listen 8041 <VirtualHost *:8041> ServerAdmin webmaster@test1.com ServerName test1.com DocumentRoot /opt/apache2.4/htdocs/test1 JkMount /*.jsp worker2 JkMount /*.do worker2 JkMount /search worker2 </VirtualHost>

8. 打开 httpd.conf  配置文件,去掉 Include conf/extra/httpd-vhosts.conf前的“#”注释
启动

二部分、集群:
另起,与上文tomcat应用无关
1、  在conf 子目录下,建立一个新的配置文件:workers.properties ,此文件为负载平衡的配置文件,文件名不能修改,这是JK 默认的名字,内容如下:

# Define list of workers that will be used apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客# for mapping requests apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.list=loadbalancer,status apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客# Define Node1 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客# modify the host as your host IP or DNS name.(服务器1) apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.node1.port=8009 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.node1.host=localhost apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.node1.type=ajp13 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.node1.lbfactor=1 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客#worker.node1.cachesize=1000 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客# Define Node2 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客# modify the host as your host IP or DNS name.(服务器2) apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.node2.port=8009 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.node2.host=10.225.69.111 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.node2.type=ajp13 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.node2.lbfactor=1 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客#worker.node2.cachesize=1000 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客#worker.node2.stopped=1 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客# Define Node3 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客# modify the host as your host IP or DNS name.(服务器3) apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.node3.port=8009 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.node3.host=10.225.69.75 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.node3.type=ajp13 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.node3.lbfactor=1 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客#worker.node3.cachesize=1000 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客#worker.node3.stopped=1 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客# Load-balancing behaviour apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.loadbalancer.type=lb apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.loadbalancer.balance_workers=node1,node2,node3 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.loadbalancer.sticky_session=1 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客 apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客#worker.list=loadbalancer apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客# Status worker for managing load balancer apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客worker.status.type=status

  2、除了通过 JKMount 设置转发路径外,你可以通过 JkMountFile 详细设置哪些 url 需要通过 mod_jk 进行负载均衡转发。通过在 APACHE_HOME/conf 目录下创建文件uriworkermap.properties 进行控制,文件格式为 /url=worker_name:
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客# Simple worker configuration file
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客# Mount the Servlet context to the ajp13 worker
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客/*=loadbalancer
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客!/*.gif=loadbalancer
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客!/*.jpg=loadbalancer
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客!/*.png=loadbalancer
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客!/*.css=loadbalancer
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客!/*.js=loadbalancer
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客!/*.htm=loadbalancer
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客!/*.html=loadbalancer
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客/prweb/*=loadbalancer
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客#/jmx-console/*=loadbalancer
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客#/web-console=loadbalancer
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客#/web-console/*=loadbalancer
apache+jkmount+tomcat - 八卦程序员 - qin1238888@126的博客

注:以上定义了三个worker,分别为node1,node2,node2;8009端口是Tomcat默认的ajp端口;定义了一个负载平衡服务器loadbalancer,相关的详细说明可以看官方的网站文档:http://tomcat.apache.org/connectors-doc/,其它节点的定义可以直接Copy,修改一下节点名及IP就好了。
A、worker.list=loadbalancer

设定工作的负载平衡器,各Tomcat节点不能加入此列表。

       B、worker.server99.lbfactor

负载平衡的权重比,如果此权重比越大,则分配到此节点的请求越多,如以上两个节点的权重比为1:1,则为平均分配。

C、worker.loadbalancer.balance_workers=node1,node2,node3

   指定此负载平衡器负责的Tomcat应用节点。

D、worker.loadbalancer.sticky_session=true

   此处指定集群是否需要会话复制,如果设为true,则表明为会话粘性,不进行会话复制,当某用户的请求第一次分发到哪台Tomcat后,后继的请求会一直分发到此Tomcat服务器上处理;如果设为false,则表明需求会话复制。当设置为0(false)时,是基于请求的负载均衡,为1(true)时是基于用户的负载均衡。

E、worker.loadbalancer.sticky_session_force=true

   如果上面的sticky_session设为true时,建议此处也设为true,此参数表明如果集群中某台Tomcat服务器在多次请求没有响应后,是否将当前的请求,转发到其它Tomcat服务器上处理;此参数在sticky_session=true时,影响比较大,会导致转发到其它Tomcat服务器上的请求,找不到原来的session,所以如果此时请求中有读取session中某些信息的话,就会导致应用的null异常。

http://blog.163.com/qin1238888@126/blog/static/865268982013522113113214/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值