整合Apache和Tomcat

这里所说的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 LoadModule proxy_http_module modules/mod_proxy_http.so
  前面的#去掉, 并在文件最后添加
  ProxyPass /images/ !
  ProxyPass / http://127.0.0.1:8009/
  ProxyPassReverse / http://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重定向回应中LocationContent-LocationURI头里的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,用Aliase 可以浏览器重直接访问该文件夹下的内容:localhost/myss

到这里基本上已经配置完了,下面我们来测试,先启动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" />

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

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

猜你喜欢

转载自feiyeguohai.iteye.com/blog/1700384