apache整合tomcat
为什么需要整合整合的最主要原因是为了在现有的硬件条件下提供最大的负载。
如果单独使用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 /test2ajp://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.iyunv.com/newsoft/Apache2.2_chinese_manual/mod/mod_proxy.html
参考: http://obunny.spaces.live.com/blog/cns!E9E883C6251F51F4!223.entry
页:
[1]