apache整合tomcat

本文介绍了Apache与Tomcat整合的原因及方法。由于Tomcat处理静态HTML能力较弱且并发连接数有限,整合方案能让Apache处理静态内容,而Tomcat专注处理JSP和Servlet请求,提高整体效率。文章详细讲解了使用mod_proxy_ajp模块进行整合的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

为什么需要整合

整合的最主要原因是为了在现有的硬件条件下提供最大的负载。
如果单独使用Tomcat做JSP服务器,在工作效率上会存在问题,Tomcat处理静态HTML的能力不如Apache,并且所能承受的最大并发连接数也有一定的限制;
在测试中,当并发连接较多时,Tomcat就会处于“僵死”状态,对后继的请求连接失去响应。所以现在提出一个“整合”解决方案:将html与jsp的功能部分进行明确分工,
让tomcat只处理jsp部分,其它的由apache这个web server处理。Apache与Tomcat各司其职,那么服务器的整体效率就能够得到提升。

整合的基本原理

作为Apache下面的子项目,Tomcat 与 Apache之间有着天然的联系。在实际操作中,主要是Apache作为主服务器运行,当监听到有jsp或者servlet的请求时,
将请求转发给tomcat服务器,由tomcat服务器进行解析后,发回apache,再由apache发回用户。在tomcat中有两个监听的端口,一个是8080用于提供web服务,
一个是8009用于监听来自于apache的请求。当apache收到jsp或者servlet请求时,就向tomcat 的8009端口发送请求,交由tomcat处理后,再返回给apache,
由apache返回给客户。


一般整合通过两种方法:
1、使用 mod_jk,这种方法配置稍嫌复杂。可以参考 http://bbs.blueidea.com/thread-2873268-1-1.html
linux下 tomcat与apache的整合 http://www.easywayserver.com/apache-tomcat-integration.html
2、使用mod_proxy_ajp 进行整合,配置比较简单。(推荐)

使用mod_proxy_ajp整合Apache2.2和Tomcat5.5
新项目需要整合Apache2.2和Tomcat5.5,具体要求是:通过 http://172.27.77.78 访问部署于Apache上的一个应用,而对于 http://172.27.77.78/c3 的request将映射到Tomcat上的c3应用,由Tomcat处理。Apache的mod_proxy_ajp就是做这个事情的,它可以说是jk2的替代者。但是mod_proxy_ajp也有缺点,其配置相对较弱,不支持对文件扩展名的模式匹配。

注意在linux上安装Apache时,默认configure时是不编译任何module的,所以在configure时要把需要的module加到参数里,例如:
./configure --prefix=/product/apache2.2 --enable-mods-shared="ssl cache proxy authn_alias mem_cache file_cache charset_lite dav_lock disk_cache"

配置mod_proxy_ajp的过程如下:

1. 在apache中加载mod_proxy_ajp相关module,确保$Apache/conf/httpd.conf中下面的line是uncomment的:
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_ajp_module modules/mod_proxy_ajp.so

2. 使用proxy_ajp配置代理:(下面的例子是在本机上进行配置的)

ProxyPass /test2/app_pic/ !
ProxyPass /test2 ajp://127.0.0.1:8009/test2
ProxyPassReverse /test2 ajp://127.0.0.1:8009/test2

访问 http://localhost:90/ 仍是在apache的目录下
访问 http://localhost:90/test2/ 则会转到 http://127.0.0.1:8080/test2

其中 ProxyPass /test2/app_pic/ ! 的含义是对于/test2/app_pic/下的请求不使用代理,也即 http://localhost:90/test2/app_pic/* 啥也没有是404
而对于其他/test2下的请求都将redirect到Tomcat的c3应用。

注意8009端口要同$Tomcat/conf/server.xml中的AJP Connector端口一致:
<!-- Define an AJP 1.3 Connector on port 8009 -->
<Connector port="8009" enableLookups="false" redirectPort="8443" protocol="AJP/1.3" />
配置完成后,重启Apache。


又例:
ProxyPass / ajp://127.0.0.1:8009
ProxyPassReverse / ajp://127.0.0.1:8009
则访问:http://localhost:90/ 则会转到 http://127.0.0.1:8080/页面,这样apache 就完全代理了 tomcat

指令 ProxyPass,ProxyPassReverse 指令解释:http://man.chinaunix.net/newsoft/Apache2.2_chinese_manual/mod/mod_proxy.html


参考: http://obunny.spaces.live.com/blog/cns!E9E883C6251F51F4!223.entry
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值