整合Apache和Tomcat
? 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,用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" />
好了,配置完毕,开始测试,测试根方案一一样,这里不说了,看上面。
时间仓促,如果有遗漏或者错误的地方,请告诉我,我会及时修正。谢谢!