1. 程式人生 > >nginx結合tomcat使用小結

nginx結合tomcat使用小結

相信很多人都聽過nginx,這個小巧的東西慢慢地在吞食apache和IIS的份額。那究竟它有什麼作用呢?可能很多人未必瞭解。

說到反向代理,可能很多人都聽說,但具體什麼是反向代理,很多人估計就不清楚了。摘一段百度百科上的描述:

Html程式碼 複製程式碼 收藏程式碼

  1. 反向代理(Reverse Proxy)方式是指以代理伺服器來接受internet上的連線請求,然後將請求轉發給內部網路上的伺服器,並將從伺服器上得到的結果返回給internet上請求連線的客戶端,此時代理伺服器對外就表現為一個伺服器。  

  這裡講得很直白。反向代理方式實際上就是一臺負責轉發的代理伺服器,貌似充當了真正伺服器的功能,但實際上並不是,代理伺服器只是充當了轉發的作用,並且從真正的伺服器那裡取得返回的資料。這樣說,其實nginx完成的就是這樣的工作。我們讓nginx監聽一個埠,譬如80埠,但實際上我們轉發給在8080埠的tomcat,由它來處理真正的請求,當請求完成後,tomcat返回,但資料此時沒直接返回,而是直接給nginx,由nginx進行返回,這裡,我們會以為是nginx進行了處理,但實際上進行處理的是tomcat。

說到上面的方式,也許很多人又會想起來,這樣可以把靜態檔案交由nginx來進行處理。對,很多用到nginx的地方都是作為靜態伺服器,這樣可以方便快取那些靜態檔案,比如CSS,JS,html,htm等檔案。

閒話就不多說了,我們直接來看看nginx怎麼使用。

 

1)要用到的軟體當然要下載啦。到nginx官網下一個。http://nginx.org/en/download.html可以到這裡去下。我現在用的版本是1.1.7,但基本上以後的版本都相容,而且我們用到的並不涉及到太底層的,應該不會有什麼變化。

這裡,由於我的是windows,當然下windows版啦。下完後首先要啟動吧。進入到nginx資料夾,直接start nginx就OK了。

比如我下載後放在D:\software\developerTools\server\nginx-1.1.7,直接cmd後cd D:\software\developerTools\server\nginx-1.1.7,有些不習慣命令列的可能會奇怪,它沒有進行到那個資料夾。windows並不會在分割槽間跳轉,除非你自己指定了。所以我們要直接d:如下:

然後,我們直接start nginx,這裡也許你會看到一個視窗一閃而過,根據我們使用tomcat的經驗,如果一閃而過,證明有錯誤了,是吧?但實際上不是。

此時我們開啟工作管理員,可以看到兩個nginx.exe在那裡好好的。這說明我們已經啟動了,至於為什麼兩個,我們這裡不深究。

現在,我們已經啟動了nginx,這時就可以啟動tomcat,想著直接訪問http://localhost就可以直接訪問tomcat了。

先不急,我們來看看啟動後的nginx是怎樣的。直接訪問http://localhost可以看到:

     我們可以看到nginx啟動成功,現在訪問是直接進到nginx的目錄裡面了。

那麼這些實際上是在哪裡配置的。這就涉及到nginx的一個重要配置檔案nginx.conf了。

 

2)我們可以看到nginx資料夾內有一個conf資料夾,其中有好幾個檔案,其他先不管,我們開啟nginx.conf,可以看到一段:

  這段程式碼在server裡面,相當於一個代理伺服器,當然可以配置多個。

下面我們仔細來分析一下:

listen:表示當前的代理伺服器監聽的埠,預設的是監聽80埠。注意,如果我們配置了多個server,這個listen要配置不一樣,不然就不能確定轉到哪裡去了。

server_name:表示監聽到之後需要轉到哪裡去,這時我們直接轉到本地,這時是直接到nginx資料夾內。

location:表示匹配的路徑,這時配置了/表示所有請求都被匹配到這裡

root:裡面配置了root這時表示當匹配這個請求的路徑時,將會在這個資料夾內尋找相應的檔案,這裡對我們之後的靜態檔案伺服很有用。

index:當沒有指定主頁時,預設會選擇這個指定的檔案,它可以有多個,並按順序來載入,如果第一個不存在,則找第二個,依此類推。

下面的error_page是代表錯誤的頁面,這裡我們暫時不用,先不管它。

 

那我們知道了具體的配置了,怎麼讓它訪問localhost時轉到tomcat時。實際上就修改兩個地方:

Java程式碼 複製程式碼 收藏程式碼

  1. server_name localhost:8080;   
  2.   
  3. location / {   
  4.     proxy_pass http://localhost:8080   
  5. }  

  我們就修改了上面兩個地方,我的tomcat在8080埠,可以根據自己的需要修改。這裡有一個新元素proxy_pass,它表示代理路徑,相當於轉發,而不像之前說的root必須指定一個資料夾。

此時我們修改了檔案,是不是就意思著必須先關了nginx再重新啟動了,其實不必,nginx可以重新載入檔案的。

我們直接執行:

Html程式碼 複製程式碼 收藏程式碼

  1. nginx -s reload  

高興得太早了,我們發現有一個錯誤:

  什麼來的,45行發現錯誤,不希望在那一行找到},於是我們仔細找,發現我們加入的proxy_pass很奇怪,沒有;號結尾,這就是問題了,直接修改,然後再執行一下,發現沒錯誤,OK了。

如果不想直接載入,而只是想看看自己的配置檔案有沒有問題,可以直接輸入:

Xml程式碼 複製程式碼 收藏程式碼

  1. nginx -t  

這可以檢查配置檔案中是否有錯。 下面我們所有的修改都假設我們修改完成後運行了nginx -s reload進行重新載入配置檔案,請注意。

 

一切沒問題了,然後我們再重新開啟http://localhost,我們看到下面的頁面:

 

這時,我們發現它並不是剛才的welcome頁面了,而是tomcat的管理頁面了,不管我們點選什麼連結都是沒問題的,相當於直接訪問http://localhost:8080一樣。

 

3)上面我們直接試了一個小例子,讓nginx進行轉發,即所謂的反向代理。但實際上我們的需求不會是這樣的,我們需要分檔案型別來進行過濾,比如jsp直接給tomcat處理,因為nginx並不是servlet容器,沒辦法處理JSP,而html,js,css這些不需要處理的,直接給nginx進行快取。

下面我們來進行一下配置,讓JSP頁面直接給tomcat,而html,png等一些圖片和JS等直接給nginx進行快取。

這時最主要用的還是location這個元素,並且涉及到一部分正則,但不難:

Xml程式碼 複製程式碼 收藏程式碼

  1. location ~ \.jsp$ {   
  2.         proxy_pass http://localhost:8080;   
  3. }   
  4.            
  5. location ~ \.(html|js|css|png|gif)$ {   
  6.     root D:/software/developerTools/server/apache-tomcat-7.0.8/webapps/ROOT;   
  7. }  

  我們先要去掉之前配的location /,避免全部請求被攔截了。

然後我們再來看看http://localhost

  當我們不指定jsp頁面的時候,它會出現找不到,因為,此時並沒有相應的location匹配,所以就會有404錯誤,這時就跳到了nginx自定義的error頁面去了。

而當我們用http://localhost/index.jsp去訪問時,我們看到了熟悉的頁面:

  而且圖片那些都顯示正常,因為圖片是png的,所以直接在tomcat/webapps/ROOT目錄下直接查詢,當然,如果我們點選Manager Application HOW-TO這個連結,我們發現:

  它還是找不到,為什麼呢?因為這是個html頁面,但它並不在ROOT目錄下,而是在docs目錄下,但當我們匹配html時,我們卻到ROOT目錄下去找,所以還是找不到這個頁面。

 

一般情況下,如果我們需要用nginx來進行靜態檔案伺服,一般都會把所有靜態檔案,html,htm,js,css等都放在同一個資料夾下,這樣就不會有tomcat這樣的情況了,因為tomcat下的是屬於不同的專案,這個我們就沒辦法了。

 

3)有些人會說,這些都只會找一臺伺服器,但如果我們想在一臺伺服器掛了的時候,自動去找另外一臺,這怎麼辦?這實際上nginx都考慮到了。

這時,我們之前用的proxy_pass就有大用途了。

我們把之前的第一個例子,即全部都代理的修改一下:

最後修改如下:

Xml程式碼 複製程式碼 收藏程式碼

  1. upstream local_tomcat {   
  2.     server localhost:8080;   
  3. }   
  4.   
  5. server{   
  6.         location / {   
  7.            proxy_pass http://local_tomcat;   
  8.         }   
  9.         #......其他省略   
  10. }  

  我們在server外添加了一個upstream,而直接在proxy_pass裡面直接用http://+upstream的名稱來使用。

我們還是直接來http://localhost,還是和第一個一樣的效果,所有連結都沒問題,說明我們配置正確。

upstream中的server元素必須要注意,不能加http://,但proxy_pass中必須加。

我們剛才說可以在一個伺服器掛了的情況下連到另外一個,那怎麼弄呢?

其實很簡單,在upstream中的local_tomcat中配置多一個server。比如我現在弄多一個jetty,埠在9999,所以我們配置如下:

Xml程式碼 複製程式碼 收藏程式碼

  1. upstream local_tomcat {   
  2.     server localhost:8080;   
  3.     server localhost:9999;   
  4. }  

  此時,我們關閉tomcat,而只開jetty。我們來執行http://localhost看看效果:

  我們看到它請求到了jetty的頁面,但由於jetty的機制,這時沒有顯示jetty主頁,這個我們先不管。但我們的在一個伺服器掛的情況下自動使用另外一個的功能實現了。

 

但有時我們就不想它掛的時候訪問另外一個,而只是希望一個伺服器訪問的機會比另外一個大,這個可以在server最後加上一個weight=數字來指定,數字越大,表明請求到的機會越大。

Xml程式碼 複製程式碼 收藏程式碼

  1. upstream local_tomcat {   
  2.     server localhost:8080 weight=1;   
  3.     server localhost:9999 weight=5;   
  4. }  

  這時我們給了jetty一個更高的權值,讓它更有機會訪問到,實際上當我們重新整理http://localhost訪問的時候發現jetty訪問機率大很多,tomcat幾乎沒機會訪問,一般情況下,如果我們必須這樣用,不要相關太大,以免一個伺服器負載太大。

當然,server還有一些其他的元素,比如down表示暫時不用到該伺服器等等。這些可以參考nginx的wiki。也許寫了一大堆,有人會有問題,那nginx怎麼關閉呢?這倒是個問題,其實直接執行nginx -s stop就可以關閉了。

 

基本上nginx的用法是這樣,深入的以後我們如果用到再學習。