您的位置:首页 > 运维架构 > Tomcat

如何整合Apache和Tomcat

2007-07-05 09:50 309 查看
这里所说的Apache是指Apache HTTP Server(后面对Apache HTTP Server简称为Apache),它是一个非常好用的web服务器,但是它只能执行静态的HTML,对于动态页面是不支持的;Tomcat本身就是一个web服务器,它可以执行jsp动态页面,也能执行静态页面,但是它解析执行静态页面远远不如Apache。那么我们可以使用Apache和Tomcat的优点,更适合我们的实际应用吗?当然可以,下面我就来介绍一下两者的整合过程。
1、使用的版本
Apache2.2.4
Tomcat5.0.28
JDK 1.4.2
mod_jk 1.21(mod_jk-apache-2.2.4.so) 注意:必须匹配apache版本

2、开始整合
整合前,请先确认以上软件都已经安装并能正常运行。在这里我就不详谈了,如果不会,请上网搜索一下。

方案一,由于apache2.2本身已经支持tomcat了,所以这里用proxy来整合tomcat
打开httpd.conf文件,把
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_ajp_module modules/mod_proxy_ajp.so
前面的#去掉, 并在文件最后添加
ProxyPass /images/ !
ProxyPass / ajp://127.0.0.1:8009/
ProxyPassReverse / ajp://127.0.0.1:8009/

先来解释一下 ProxyPass和 ProxyPassReverse指令
语法:ProxyPass [路径] !|url
说明:将一个远端服务器映射到本地服务器的URL空间中
该指令对于您不想对某个子目录进行反向代理时很有用。比如说:

ProxyPass /mirror/foo/i !
ProxyPass /mirror/foo http://foo.com


将会代理所有对 foo.com 的/mirror/foo请求,但是对/mirror/foo/i请求除外。

语法:ProxyPassReverse [路径] !|url
说明:调整由反向代理服务器发送的HTTP回应头中的URL

此指令使 Apache 调整HTTP重定向回应中
Location
Content-Location
URI
头里的URL。这就是Apache在作为反向代理使用时,避免以因为位于反向代理之后的后端服务器的HTTP重定向造成的绕过反向代理的实质。

路径是本地虚拟路径的名称。
url远端服务器的部分URL。与
ProxyPass
指令中的使用方法相同。

示例:
假定本地服务器拥有地址
http://wibble.org/
;那么

ProxyPass /mirror/foo/ http://foo.com/ ProxyPassReverse /mirror/foo/ http://foo.com/


不仅会把所有对<
http://wibble.org/mirror/foo/bar
>的请求直接转为对 <
http://foo.com/bar
> 的代理请求,(由
ProxyPass
提供的功能)。它还会改变服务器foo.com的发送:当
http://foo.com/bar
被它重定向到
http://foo.com/quux
时,Apache会在前转HTTP重定向回应到客户端之前调整它为
http://wibble.org/mirror/foo/quux


以上指令说明,请参照http://kajaa.bbs.us/ApacheManual/zh-cn/mod/mod_proxy.html#proxypass

好,下面继续修改httpd.conf文件,添加下面的语句,注意myss是我做的一个Web项目,请替换成你自己的Web项目。

Alias /myss "D:/ApacheSoftware/Tomcat 5.0/webapps/myss"
<Directory "D:/ApacheSoftware/Tomcat 5.0/webapps/myss">
Options Indexes FollowSymLinks
AllowOverride None
Order allow,deny
Allow from all
</Directory>

Alias 指令映射URL到文件系统的特定区域,关于该指令请参照http://kajaa.bbs.us/ApacheManual/zh-cn/mod/mod_alias.html#alias

到这里基本上已经配置完了,下面我们来测试,先启动Apache,再启动Tomcat,然后打开IE,在地址栏中输入http://localhost/myss,成功出现登录页面,然后再打开一个IE,在地址栏中输入http://localhost:8080/myss,这是在tomcat下的页面,两个应该是一样的。

方案二:上面的整合使用的是Apache自带的proxy,下面我们来看看用mod_jk如何进行整合。

首先,下载mod_jk-apache-2.2.4.so文件,然后把这个文件放到Apache安装目录/modules下;

然后修改 Apache安装目录/conf/httpd.conf文件;

在httpd.conf文件的最后添加apache_tomcat连接器mod-jk配置文件路径:
# Tomcat mod-jk
Include conf/mod_jk.conf

Alias /myss "D:/ApacheSoftware/Tomcat 5.0/webapps/myss"
<Directory "D:/ApacheSoftware/Tomcat 5.0/webapps/myss">
Options Indexes FollowSymLinks
AllowOverride None
Order allow,deny
Allow from all
</Directory>

接着在Apache安装目录/conf/下新建文件mod_jk.conf,内容如下:

# Load mod_jk module. Specify the filename
# of the mod_jk lib you’ve downloaded and
# installed in the previous section
#加载mod_jk模块
LoadModule jk_module modules/mod_jk-apache-2.2.4.so
# Where to find workers.properties
JkWorkersFile conf/workers.properties
# Where to put jk logs
JkLogFile logs/mod_jk.log
# Set the jk log level [debug/error/info]
JkLogLevel info
# Select the log format
JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "
# JkOptions indicate to send SSL KEY SIZE,
JkOptions +ForwardKeySize +ForwardURICompat -ForwardDirectories
# JkRequestLogFormat set the request format
JkRequestLogFormat "%w %V %T"
# 请求分发配置,可以配置多项
JkMount /myss/* worker1

JkUnMount /*.html worker1
#把/myss/目录下的所有请求转发给集群负载均衡器(最终到达tomcat),但是html文件除外
#关掉主机Lookup,提高系统性能。
HostnameLookups Off

然后在Apache安装目录/conf/下新建文件workers.properties,内容如下
worker.list=worker1,server1 #server 列表
# Define the first node...
worker.server1.port=8009 #ajp13 端口号,在tomcat下server.xml配置,默认8009
worker.server1.host=127.0.0.1 #tomcat服务器ip地址
worker.server1.type=ajp13
worker.server1.lbfactor=1 #server的加权比重,值越高,分得的请求越多
worker.server1.socket_keepalive=1
worker.server1.socket_timeout=0
worker.server1.retries=3

# Define the second node...
# 在这里还可以再配置一个Tomcat来达到负载均衡,关于集群和负载均衡,我就不详细说明了,有兴趣的朋友可以上网查查
# Now we define the load-balancing behaviour
worker.worker1.type=lb
worker.retries=3
worker.worker1.balance_workers=server1 #指定分担请求的tomcat
worker.worker1.sticky_session=true
worker.worker1.sticky_session_force=true

最后,确认 Tomcat安装目录/conf下的server.xml文件包含下面的配置:

<!-- Define a Coyote/JK2 AJP 1.3 Connector on port 8009 -->
<Connector port="8009"
enableLookups="false" redirectPort="8443" debug="0"
protocol="AJP/1.3" />

好了,配置完毕,开始测试,测试根方案一一样,这里不说了,看上面。

时间仓促,如果有遗漏或者错误的地方,请告诉我,我会及时修正。谢谢!

注意:

当把Tomcat5.0换成Tomcat5.5,其他的不变,这种情况下,如果通过Apache访问Tomcat时,CPU占用率居高不下,一直是90%以上,但是如果直接访问Tomcat,就没有这个问题,我想问题应该出在mod_jk这里,但是具体是什么原因我也说不清楚。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: