试验目的和环境:一共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 [email protected]
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 [email protected]
DocumentRoot /www/docs/virtual-hosts(虚拟主机的根目录)
ServerName 192.168.78.88 Alias /jingtai "/www/docs/virtual-hosts/jingtai"(若出现对:"http://192.168.78.88/jingtai"页面的访问,则跳转到:"http://192.168.78.88/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标准输出上是否有输出: