Apache HTTP Server 官方网站:http://httpd.apache.org/
Apache Tomcat 官方网站:http://tomcat.apache.org/
mod_jk 所有版本列表:http://archive.apache.org/dist/tomcat/tomcat-connectors/jk/
测试环境:
apache 2.2.3
apache-tomcat 6.0.35
jdk1.6.0_34
下载 mod_jk.so:
wget http://bukn.org:8001/downloads/mod_jk/32/mod_jk.so -P /usr/lib/
wget http://bukn.org:8001/downloads/mod_jk/64/mod_jk.so -P /usr/lib64/httpd/modules/
chmod +x /usr/lib/mod_jk.so
chmod +x /etc/httpd/modules/mod_jk.so
配置 mod_jk.conf
touch /etc/httpd/conf.d/mod_jk.conf
vi /etc/httpd/conf.d/mod_jk.conf
mod_jk.conf 内容如下:
# (httpd.conf)
# 加载 mod_jk 模块
LoadModule jk_module modules/mod_jk.so
#
# Configure mod_jk
#
JkWorkersFile conf/workers.properties
JkMountFile conf/uriworkermap.properties
JkLogFile logs/mod_jk.log
JkLogLevel warn
在conf目录新建workers.properties与uriworkermap.properties文件并进行修改
#
# workers.properties
#
# list the workers by name
worker.list=tomcatserver, status
# localhost server 1
# ------------------------
worker.s1.port=8109
worker.s1.host=localhost
worker.s1.type=ajp13
# localhost server 2
# ------------------------
worker.s2.port=8209
worker.s2.host=localhost
worker.s2.type=ajp13
worker.s2.stopped=1
worker.tomcatserver.type=lb
worker.retries=3
worker.tomcatserver.balanced_workers=s1, s2
worker.tomcatserver.sticky_session=1
worker.status.type=status
稍作解释一下以上的 workers.properties 配置。
首先我们配置了两个类型为 ajp13 的 worker 分别是 s1 和 s2,注意它们指向同一台服务器上运行在两个不同端口 8109 和 8209 的 Tomcat 上(Tomcat 默认的端口为8009)。
接下来我们配置了一个类型为 lb(也就是负载均衡的意思)的 worker,它的名字是 tomcatserver,这是一个逻辑的 worker,它用来管理前面配置的两个物理连接 s1 和 s2。
最后还配置了一个类型为 status 的 worker,这是用来监控 JK 本身的模块。
有了这三个 worker 还不够,我们还需要告诉 JK,哪些 worker 是可用的,所以就有 worker.list = tomcatserver, status 这行配置。
再来配置一下 uriworkermap.properties
/*=tomcatserver #所有的请求都由 tomcatserver 这个 worker 进行处理
/jkstatus=status #/jkstatus 请求由 status 这个 worker 处理
# 以下都不需要用 tomcatserver 来处理,直接交给 apache 处理。
!/*.gif=tomcatserver
!/*.jpg=tomcatserver
!/*.png=tomcatserver
!/*.css=tomcatserver
!/*.js=tomcatserver
!/*.htm=tomcatserver
!/*.html=tomcatserver
所有的请求都由 tomcatserver 这个 worker 进行处理,但是有几个例外,/jkstatus 请求由 status 这个 worker 处理。另外这个配置中每一行数据前面的感叹号是什么意思呢?感叹号表示接下来的 URI 不要由 JK 进行处理,也就是 Apache 直接处理所有的图片、css 文件、js 文件以及静态 html 文本文件。
附上 mod_jk.conf 与 workers.properties 配置文件:
mod_jk.conf 配置
LoadModule jk_module modules/mod_jk.so
JkWorkersFile workers.properties
JkLogLevel info
#JkLogFile /var/log/httpd/mod_jk.log
JkMount /*.jsp tomcatServer
JkMount /*.do tomcatServer
JkMount /*.cfg tomcatServer
JkMount /*.action tomcatServer
JkMount /*.code tomcatServer
JkMount /*.fileupload tomcatServer
JkMount /*.php tomcatServer
workers.properties 配置
#指定文件路径分割符
ps=\
#模块版本,即Server列
worker.list=tomcatServer
#==========tomcatServer============#
worker.tomcatServer.port=8009 #工作端口,若没占用则不用修改
worker.tomcatServer.host=127.0.0.1 #本机,若上面的Apache主机不为localhost,作相应修改
worker.tomcatServer.type=ajp13 #类型ve
worker.tomcatServer.lbfactor=1 #server的加权比重,值越高,分得的请求越多
worker.tomcatServer.socket_keepalive=true