天天看點

Apache HTTP Server與Tomcat整合學習記錄

前言

其實網上有很多教程,但問題是得每次找個正确率很高的卻很難。是以在此做個簡單的記錄,友善快速查找。

注意:

  • 關于JDK環境配置在此不多贅述。
  • Tomcat9版本配置中将AJP的配置注釋了,是以很多人整合不合适
  • 下面會用到cmd指令視窗,一定要以管理者身份打開,否則權限不夠。

開始整合一、下載下傳安裝Apache HTTP Server

第一步:下載下傳解壓縮

下載下傳位址:https://www.apachehaus.com/cgi-bin/download.plx

Apache HTTP Server與Tomcat整合學習記錄

第二步:配置檔案

打開conf檔案夾,修改其中“httpd.conf”檔案配置;更改為自己的檔案安放路徑

Apache HTTP Server與Tomcat整合學習記錄
Apache HTTP Server與Tomcat整合學習記錄

第三步:安裝

用管理者身份打開cmd,進入檔案bin目錄所在位置,并輸入以下指令

# 服務名可以自定義,這裡我的是Apache24
httpd -k install -n "Apache24"
# 解除安裝
httpd -k uninstall -n "Apache24"      
Apache HTTP Server與Tomcat整合學習記錄

同時可以打開同級目錄下的ApacheMonitor程式

第四步:啟動

# 啟動 Apache 服務
httpd.exe -k start -n "Apache24"
# 重新開機 Apache 服務
httpd.exe -k restart -n "Apache24"
# 停止 Apache 服務
httpd.exe -k stop -n "Apache24"      

并檢視是否啟動成功,如果可以成功通路localhost:80或者ApacheMonitor程式中按鈕亮起說明安裝啟動成功

二、下載下傳安裝Tomcat

在此也不做多餘贅述,隻需去官網下載下傳解壓即可

下載下傳位址:https://tomcat.apache.org/download-80.cgi

第二步:進入bin目錄,輕按兩下startup.bat即可

注意:個人是未修改原始檔案配置資訊,是以不是從原始檔案開始更改的,可能問題在自己的配置上。

三、整合-下載下傳JK子產品

下載下傳位址:http://archive.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/windows/

注意:根據自己的需求版本比對進行下載下傳,個人這裡是下載下傳的1.2.40版本

Apache HTTP Server與Tomcat整合學習記錄

第二步:複制mod_jk.so

解壓縮後,找到mod_jk.so檔案,然後将檔案複制到Apache下的modules檔案夾下

Apache HTTP Server與Tomcat整合學習記錄

第三步:建立“mod_jk.conf”檔案

步驟圖

Apache HTTP Server與Tomcat整合學習記錄

在Apache下的conf檔案夾下建立

輸入以下檔案内容

#加載mod_jk Module     
LoadModule jk_module modules/mod_jk.so         
#指定 workers.properties檔案路徑     
JkWorkersFile conf/workers.properties       
#指定那些請求交給tomcat處理,"controller"為在workers.propertise裡指定的負載配置設定控制器      
JkMount /*.do controller
JkMount /*WEB-INF controller
JkMount /*j_spring_security_check controller
JkMount /*.action controller
JkMount /servlet/* controller
JkMount /*.jsp controller
JkMount /*.do controller
JkMount /*.action controller
JkMount /* controller      

第四步:修改httpd.conf檔案

去Apache下,找到該配置檔案,在檔案末尾添加一段代碼,引入mod_jk.conf配置檔案

Include conf/mod_jk.conf      

第五步:建立“workers.properties”

worker.list =controller,tomcat1,tomcat2   #server 清單
#========tomcat1========    
worker.tomcat1.port=8009       #ajp13 端口号,在tomcat下server.xml配置,預設8009
worker.tomcat1.host=localhost  #tomcat的主機位址,如不為本機,請填寫ip位址 
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor = 1    #server的權重比重,值越高,分得的請求越多 
#========tomcat2========  
#worker.tomcat2.port=8019
#worker.tomcat2.host=localhost
#worker.tomcat2.type=ajp13
#worker.tomcat2.lbfactor = 1
#========controller,負載均衡控制器========   
worker.controller.type=lb
#指定分擔請求的tomcat 
worker.controller.balanced_workers=tomcat1,tomcat2      
#回話是否有粘性,false表示無粘性,同一個回話的請求會到不同的tomcat中處理
worker.controller.sticky_session=false               
#當一個節點蹦了,如果設值為true,那麼伺服器傳回500錯誤給用戶端,如果設值為false,則轉發給其他的tomcat,但是會丢失回話資訊
worker.controller.sticky_session_force=false      

建議

看網上有人說先啟動Apache再去啟動Tomcat這樣不會出問題,這個點可以注意一下,雖然我個人沒遇到。

如果其中會碰到問題,可以參考該博文https://blog.csdn.net/dongdong9223/article/details/64921439

關于Tomcat中AJP的配置

Apache HTTP Server與Tomcat整合學習記錄

第一個連接配接器監聽8080端口,負責建立HTTP連接配接。在通過浏覽器通路Tomcat伺服器的Web應用時,使用的就是這個連接配接器。

第二個連接配接器監聽8009端口,負責和其他的HTTP伺服器建立連接配接。在把Tomcat與其他HTTP伺服器內建時,就需要用到這個連接配接器。AJP連接配接器可以通過AJP協定和一個web容器進行互動。

關于proxy、proxy_blancer和mod_jk的比較

  1. proxy的缺點是,當其中一台tomcat停止運作的時候,apache仍然會轉發請求過去,導緻502網關錯誤。但是隻要伺服器再啟動就不存在這個問題。
  2. mod_jk方式的優點是,Apache 會自動檢測到停止掉的tomcat,然後不再發請求過去。

    缺點就是,當停止掉的tomcat伺服器再次啟動的時候,Apache檢測不到,仍然不會轉發請求過去。

  3. proxy和mod_jk的共同優點是.可以隻将Apache置于公網,節省公網IP位址資源。

    可以通過設定來實作Apache專門負責處理靜态網頁,讓Tomcat專門負責處理jsp和servlet等動态請求。

    共同缺點是:如果前置Apache代理伺服器停止運作,所有叢集服務将無法對外提供。

  4. proxy和mod_jk對靜态頁面請求的處理,都可以通設定來選取一個盡可能優化的效果。

    mod_proxy_balancer和mod_jk都需要修改tomcat的配置檔案配合

  5. 這三種Tomcat叢集方式對實作最佳負載均衡都有一定不足,mod_proxy_balancer和mod_jk相對好些,mod_jk的設定能力更強些。lbfactor參數來配置設定請求任務。
  6. apache自帶mod_proxy功能子產品中目前隻可以實作兩種不同的負載均衡叢集實作方式,第一種是分工合作的的形式,通過各台主機負責不同的任務而實作任務分工。第二種是不同的機器在擔任同樣的任務,某台機器出現故障主機可以自動檢測到将不會影響到用戶端,而第一種卻不能實作但第一種實作方式的優點在于他是主伺服器負擔相應沒第二種大因為台隻是提供跳轉指路功能,形象的說他不給你帶路隻是告訴你有條路可以到,但到了那是否可以看到你見的人他已經不會去管你了。相比之下第二種性能要比第一種會好很多;但他們都有個共同點都是一托N形式來完成任務的是以你的主機性能一定要好。

關于apache整合tomcat部署叢集

可參考該博文:apache整合tomcat部署叢集

Tomcat優化(未親測)

在service.xml檔案裡加入

maxThreads="800" minSpareThreads="25" maxSpareThreads="700" enableLookups="false" acceptCount="1200"

maxThreads=”150” 表示最多同時處理150個連接配接

minSpareThreads=”25” 表示即使沒有人使用也開這麼多空線程等待

maxSpareThreads=”75” 表示如果最多可以空75個線程,例如某時刻有80人通路,之後沒有人通路了,則tomcat不會保留80個空線程,而是關閉5個空的。

acceptCount=”100” 當同時連接配接的人數達到maxThreads時,還可以接收排隊的連接配接,超過這個連接配接的則直接傳回拒絕連接配接

Apache+Tomcat配置測試

測試Tomcat

首先空項目跑一下,看tomcat能否正常啟動

然後加項目跑一下,看tomcat能否正常啟動

測試Apache

Tomcat啟動後重新開機一下Apache服務,看能否啟動

注意:Apache有可能啟動不起來,那麼解決方式是檢視Apache安裝目錄下的logs目錄下的error.log檔案,

根據log檔案解決可能存在的問題。直到Apache可以正常啟動,至此Apache就可以正常啟動了。

最後

繼續閱讀