linux下apache+tomcat+jk负载均衡配置全过程原文出处%3D1#pid5497445
试验目的和环境:
一共2台服务器,均为AS3,一台为:192.168.78.88,计划作为webserver,接受静态网页请求,安装apache,tomcat,
jakarta-tomcat-connectors;另外一台为:192.168.71.77,计划安装tomcat,若请求非静态,则负载均衡到两个
机器一起负担。
试验所需软件:
apache-tomcat-5.5.17.tar.gz,httpd-2.2.2.tar.gz,jakarta-tomcat-connectors-1.2.15-src.tar.gz
安装过程:由于apache和tomcat为以前多次安装,故基本步骤省略;
jakarta-tomcat-connectors-1.2.15-src.tar.gz的安装步骤如下:
1,tar -zxvf jakarta-tomcat-connectors-1.2.15-src.tar.gz;
cd jakarta-tomcat-connectors-1.2.15-src/jk/native;
2,./configure --with-apxs=/usr/local/apache/bin/apxs;
make;
su -c 'make install';
3,cp jakarta-tomcat-connectors-1.2.15-src/jk/native/apache-2.0/mod_jk.so /usr/local/apache/modules
APACHE端的配置:
1,对于/usr/local/apache/conf/worker.properties,一般需要自己添加:
worker.master.type=lb(master作为负载均衡)
worker.master.balance_workers=worker1,worker2(两台机器上的两个tomcat作为worker)
worker.master.sticky_session=true
worker.master.sticky_session_force=false
worker.worker1.type=ajp13
worker.worker1.host=192.168.78.88
worker.worker1.port=8009
worker.worker1.socket_timeout=300
worker.worker1.recycle_timeout=0
worker.worker1.lbfactor=1(优先级)
worker.worke2.type=ajp13
worker.worker2.host=192.168.71.77
worker.worker2.port=8009
worker.worker2.socket_timeout=300
worker.worker2.recycle_timeout=0
worker.worker2.lbfactor=1(同上,优先级,若数值越大,则优先级越高)
2,对于/usr/local/apache/conf/httpd.conf
1)特殊配置,# LoadModule foo_module modules/mod_foo.so
LoadModule jk_module modules/mod_jk.so(加载这个模块)
JkWorkersFile
/usr/local/apache/conf/worker.properties(用worker.properties的规则来实现jk,指定jk
workers.properties的位置,如果是相对路径,则假定在apache的ServerRoot目录下。)
JkLogFile /usr/local/apache/logs/jk.log(指定jk log文件的位置,如果是相对路径,则假定在apache的ServerRoot目录下。)
JkLogLevel info (指定jk log的级别有效的选项有:debug/error/info )
JkRequestLogFormat "%w %V %T"
JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "( 指定log中的时间格式,使用c函数strftime()的格式字符串语法)
2),一般配置:
ServerAdmin zhq@zhq.edu.cn
ServerName 192.168.78.88:8888
DocumentRoot "/usr/local/apache/htdocs"
Options FollowSymLinks
AllowOverride None
说明:以上是对本身默认的主页的访问目录的设置,不难发现,我已经把主页的端口改成8888,不合下面的虚拟主机冲突,此处不会遵从下面的负载均衡的分配法则。
Options Indexes FollowSymLinks
AllowOverride None
Order allow,deny
Allow from all
说明:此处为我对虚拟主机所在目录的设置。
3),虚拟主机
NameVirtualHost *:80
ServerAdmin zhq@zhq.edu.cn
DocumentRoot /www/docs/virtual-hosts(虚拟主机的根目录)
ServerName 192.168.78.88
Alias /jingtai
"/www/docs/virtual-hosts/jingtai"(若出现对:""页面的
访问,则跳转到:"")
Alias /dongtai "/www/docs/virtual-hosts/dongtai"(同上理)
ErrorLog "/usr/local/apache/logs/error_log combined"
JkUnMount /index.html master(若出现对index.html的访问,则不用jk到master)
JkMount /index.jsp master(若出现对index.jsp的访问,则要用master来做负载均衡)
TOMCAT端的配置:
仅用分别在两台机的tomcat里,对/home/zhq/apache-tomcat-5.5.17/conf/server.xml进行修改,具体如下:
在jvmRoute=“”中填入指定的worker,在本例中,78.88填入:worker1; 71.77填入:worker2;
说明:
在最新的tomcat版本中该Connector默认情况下是启用的。启动tomcat,检查ajp13服务是否运行;
netstat -a | grep 8009
或则查看tomcat标准输出上是否有类似的输出:
Jul 18, 2006 7:47:02 PM org.apache.jk.common.ChannelSocket init
INFO: JK: ajp13 listening on /0.0.0.0:8009
阅读(1051) | 评论(0) | 转发(0) |