ProxyPass / ajp://127.0.0.1:8009/
ProxyPassReverse / ajp://127.0.0.1:8009/
ProxyPass /mirror/foo/i !
ProxyPass /mirror/foo http://foo.com
將會代理所有對 foo.com 的/mirror/foo請求,但是對/mirror/foo/i請求除外。
此指令使 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" />
好了,配置完畢,開始測試,測試根方案一一樣,這裏不說了,看上面。
時間倉促,如果有遺漏或者錯誤的地方,請告訴我,我會及時修正。謝謝!
注意: