/ 中存储网

Tomcat与Apache的整合配置(mod_jk)

2013-12-30 09:33:01 来源:itjs.cn

Tomcat与Apache整合(mod_jk):

从Tomcat权威指南中的测试数据,我们不难发现,对于静态页面的数据,Tomcat的处理速度比Apache要快很多,

所以为什么要整合 apache?虽然在处理静态页面速度上比Apache快,但是Tomcat经不起大的并发量,容易死。为此,我们就需要Apache,虽然Apache的速度要慢一

些,但能承受的起大的并发量。因此,有了本文。

三种负载:

mod_proxy_http 是 APAHCE 的 HTTP proxy,对静态页面还好,对动态页面效果不佳。

mod_proxy_ajp ,  是 APACHE 的 AJP 的 proxy, 好像是 apache 2.2 以后的版本才有(最好还是去对文档看看),只支持 AJP 13

mod_jk ,是 tomcat 的 apache 扩展 module(tomcat-connectors),可支持 AJP 12/13,JNI 以及 Loadblance.

简单多就是跟proxy 效果虽然差不多但不是一个起跑线。

整个思路:

1、安装Apache

2、安装tomcat

3、安装mod_jk

4、加载mod_jk

5、关闭tomcat的侦听端口

6、应用分离(静态与动态页面分离)

环境介绍:

OS:CentOS 5.7

SOFT:Tomcat 6.0+JDK 1.6+Apache 2.2

编译安装apache

# ./configure --prefix=/usr/local/apache2  --enable-proxy-balancer

--enable-proxy-http --enable-proxy-connect  --enable-proxy

--enable-rewrite --enable-proxy-ajp

中间曾发生过,make失败的情况,最后发现是部分文件的所有者没有变为root,造成失败!

# make && make install

编译模块mod_jk:  

# tar -xzf tomcat-connectors-1.2.32-src.tar.gz

# cd tomcat-connectors-1.2.32-src/

# cd native/

# ./configure --with-apxs=/usr/local/apache2/bin/apxs

# make && make install

# ll /usr/local/apache2/modules/mod_jk.so

-rwxr-xr-x 1 root root 1076923 Feb 20 19:14 /usr/local/apache2/modules/mod_jk.so

加载模块mod_jk:

# vim /usr/local/apache2/conf/httpd.conf

LoadModule jk_module modules/mod_jk.so

JkWorkersFile /usr/local/apache2/conf/workers.properties

JkMountFile   /usr/local/apache2/conf/uriworkermap.properties

JkLogFile /usr/local/apache2/logs/mod_jk.log

JkLogLevel info

JkLogStampformat "[%a %b %d %H:%M:%S %Y]"

建立相关定义的文件

# touch /usr/local/apache2/conf/workers.properties

# touch /usr/local/apache2/conf/uriworkermap.properties

# touch /usr/local/apache2/logs/mod_jk.log

# cat workers.properties   #定义tomcat主机

worker.list=tomcat2

worker.tomcat2.type=ajp13

worker.tomcat2.host=localhost

worker.tomcat2.port=8009

worker.tomcat2.lbfactor=1

# cat uriworkermap.properties  #定义tomcat处理的文件类型,tomcat不处理的由apache来处理。

/*=tomcat2

!/*.jpg=tomcat2

!/*.gif=tomcat2

!/*.png=tomcat2

!/*.bmp=tomcat2

!/*.html=tomcat2

!/*.htm=tomcat2

!/*.swf=tomcat2

!/*.css= tomcat2

!/*.js= tomcat2

关闭tomcat的侦听商品起见(主要是为安全考虑)

<!--

<Connector port="8080" protocol="HTTP/1.1"

   connectionTimeout="20000"

   redirectPort="8443" />

-->

应用分离:

将apache的文档目录修改到/data/webapps,将tomcat的目录修改到/data/webapps

Apache的修改文档目录位置:

DocumentRoot "/data/webapps"

......

<Directory "/data/webapps">

tomcat修改的值:

<Host name="localhost"  appBase="/data/webapps"

unpackWARs="true" autoDeploy="true"

xmlValidation="false" xmlNamespaceAware="false">

完成以上部署之后,我们就可以启动apache、tomcat了。访问http://localhost来看看!

如何判断,页面是真的分离了呢? 通过不存在的页面,来看报错信息就行了。

如何确认,mod_jk真正被加载了?

方法:查看mod_jk的日志。如果出现:

[info] init_jk::mod_jk.c (3252): mod_jk/1.2.32 () initialized 就表明它已经被正常的加载了。

我不认为,安装完就结束了,其实它只是另一个开始而已。

关于虚拟机的部分:

以上操作只是对一台机器的动静分离,如果是在某台机器上,有多个虚拟机,并且各自的路径不一样怎么办?

这个问题,只需要通过在每个虚拟机里定义相应的uriworkermap.properties文件就行了。

<VirtualHost *>

 ServerAdmin [email protected]

 DocumentRoot /data/www

 ServerName 192.168.1.8

 ErrorLog logs/error_log

 CustomLog logs/access_log common

 JkMountFile  conf/uriworkermap.properties

</VirtualHost>