如何整合Apache和Tomcat (兩種方式1.Apache自帶的proxy 2.mod_jk 1.21(mod_jk-apache-2.2.4.so))

這裏所說的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 proxy_ajp_module modules/mod_proxy_ajp.so
  前面的#去掉, 並在文件最後添加
  ProxyPass /images/ !
  ProxyPass / ajp://127.0.0.1:8009/
  ProxyPassReverse / ajp://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

到這裏基本上已經配置完了,下面我們來測試,先啓動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" />

好了,配置完畢,開始測試,測試根方案一一樣,這裏不說了,看上面。

時間倉促,如果有遺漏或者錯誤的地方,請告訴我,我會及時修正。謝謝!

 注意:

當把Tomcat5.0換成Tomcat5.5,其他的不變,這種情況下,如果通過Apache訪問Tomcat時,CPU佔用率居高不下,一直是90%以上,但是如果直接訪問Tomcat,就沒有這個問題,我想問題應該出在mod_jk這裏,但是具體是什麼原因我也說不清楚。
發佈了38 篇原創文章 · 獲贊 4 · 訪問量 10萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章