linux下apache+tomcat+jk负载均衡配置全过程

试验目的和环境:一共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标准输出上是否有输出:

你可能感兴趣的:(apache,tomcat,linux,虚拟机,socket)