欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Nginx為Tomcat服務(wù)器作反向代理的配置教程

 更新時間:2016年03月18日 09:54:09   作者:柏樹_Jeff  
這篇文章主要介紹了Nginx為Tomcat服務(wù)器作反向代理的配置教程,文中以Windows系統(tǒng)為環(huán)境來演示驅(qū)動JSP程序的示例,需要的朋友可以參考下

web上的server都叫web server,但是大家分工也有不同的。

nginx常用做靜態(tài)內(nèi)容服務(wù)和代理服務(wù)器(不是你FQ那個代理),直面外來請求轉(zhuǎn)發(fā)給后面的應(yīng)用服務(wù)(tomcat,django什么的),tomcat更多用來做做一個應(yīng)用容器,讓java web app跑在里面的東西,對應(yīng)同級別的有jboss,jetty等東西。

但是事無絕對,nginx也可以通過模塊開發(fā)來提供應(yīng)用功能,tomcat也可以直接提供http服務(wù),通常用在內(nèi)網(wǎng)和不需要流控等小型服務(wù)的場景。

apache用的越來越少了,大體上和nginx功能重合的更多。

嚴(yán)格的來說,Apache/Nginx 應(yīng)該叫做「HTTP Server」;而 Tomcat 則是一個「Application Server」,或者更準(zhǔn)確的來說,是一個「Servlet/JSP」應(yīng)用的容器(Ruby/Python 等其他語言開發(fā)的應(yīng)用也無法直接運(yùn)行在 Tomcat 上)。

一個 HTTP Server 關(guān)心的是 HTTP 協(xié)議層面的傳輸和訪問控制,所以在 Apache/Nginx 上你可以看到代理、負(fù)載均衡等功能。客戶端通過 HTTP Server 訪問服務(wù)器上存儲的資源(HTML 文件、圖片文件等等)。通過 CGI 技術(shù),也可以將處理過的內(nèi)容通過 HTTP Server 分發(fā),但是一個 HTTP Server 始終只是把服務(wù)器上的文件如實(shí)的通過 HTTP 協(xié)議傳輸給客戶端。

而應(yīng)用服務(wù)器,則是一個應(yīng)用執(zhí)行的容器。它首先需要支持開發(fā)語言的 Runtime(對于 Tomcat 來說,就是 Java),保證應(yīng)用能夠在應(yīng)用服務(wù)器上正常運(yùn)行。其次,需要支持應(yīng)用相關(guān)的規(guī)范,例如類庫、安全方面的特性。對于 Tomcat 來說,就是需要提供 JSP/Sevlet 運(yùn)行需要的標(biāo)準(zhǔn)類庫、Interface 等。為了方便,應(yīng)用服務(wù)器往往也會集成 HTTP Server 的功能,但是不如專業(yè)的 HTTP Server 那么強(qiáng)大,所以應(yīng)用服務(wù)器往往是運(yùn)行在 HTTP Server 的背后,執(zhí)行應(yīng)用,將動態(tài)的內(nèi)容轉(zhuǎn)化為靜態(tài)的內(nèi)容之后,通過 HTTP Server 分發(fā)到客戶端。

說到反向代理,可能很多人都聽說,但具體什么是反向代理,很多人估計(jì)就不清楚了。摘一段百度百科上的描述:反向代理(Reverse Proxy)方式是指以代理服務(wù)器來接受internet上的連接請求,然后將請求轉(zhuǎn)發(fā)給內(nèi)部網(wǎng)絡(luò)上的服務(wù)器,并將從服務(wù)器上得到的結(jié)果返回給internet上請求連接的客戶端,此時代理服務(wù)器對外就表現(xiàn)為一個服務(wù)器。 
  這里講得很直白。反向代理方式實(shí)際上就是一臺負(fù)責(zé)轉(zhuǎn)發(fā)的代理服務(wù)器,貌似充當(dāng)了真正服務(wù)器的功能,但實(shí)際上并不是,代理服務(wù)器只是充當(dāng)了轉(zhuǎn)發(fā)的作用,并且從真正的服務(wù)器那里取得返回的數(shù)據(jù)。這樣說,其實(shí)nginx完成的就是這樣的工作。我們讓nginx監(jiān)聽一個端口,譬如80端口,但實(shí)際上我們轉(zhuǎn)發(fā)給在8080端口的tomcat,由它來處理真正的請求,當(dāng)請求完成后,tomcat返回,但數(shù)據(jù)此時沒直接返回,而是直接給nginx,由nginx進(jìn)行返回,這里,我們會以為是nginx進(jìn)行了處理,但實(shí)際上進(jìn)行處理的是tomcat。說到上面的方式,也許很多人又會想起來,這樣可以把靜態(tài)文件交由nginx來進(jìn)行處理。對,很多用到nginx的地方都是作為靜態(tài)伺服器,這樣可以方便緩存那些靜態(tài)文件,比如CSS,JS,html,htm等文件。閑話就不多說了,我們直接來看看nginx怎么使用。
1)要用到的軟件當(dāng)然要下載啦。到nginx官網(wǎng)下一個。http://nginx.org/en/download.html可以到這里去下。我現(xiàn)在用的版本是1.1.7,但基本上以后的版本都兼容,而且我們用到的并不涉及到太底層的,應(yīng)該不會有什么變化。這里,由于我的是windows,當(dāng)然下windows版啦。下完后首先要啟動吧。進(jìn)入到nginx文件夾,直接start nginx就OK了。比如我下載后放在D:\software\developerTools\server\nginx-1.1.7,直接cmd后cd D:\software\developerTools\server\nginx-1.1.7,有些不習(xí)慣命令行的可能會奇怪,它沒有進(jìn)行到那個文件夾。windows并不會在分區(qū)間跳轉(zhuǎn),除非你自己指定了。所以我們要直接d:如下:

201631895050245.png (511×106)

然后,我們直接start nginx,這里也許你會看到一個窗口一閃而過,根據(jù)我們使用tomcat的經(jīng)驗(yàn),如果一閃而過,證明有錯誤了,是吧?但實(shí)際上不是。

201631895111556.png (480×62)

此時我們打開任務(wù)管理器,可以看到兩個nginx.exe在那里好好的。這說明我們已經(jīng)啟動了,至于為什么兩個,我們這里不深究。

201631895131495.png (150×54)

現(xiàn)在,我們已經(jīng)啟動了nginx,這時就可以啟動tomcat,想著直接訪問http://localhost就可以直接訪問tomcat了。先不急,我們來看看啟動后的nginx是怎樣的。直接訪問http://localhost可以看到:

201631895151494.png (860×109)

我們可以看到nginx啟動成功,現(xiàn)在訪問是直接進(jìn)到nginx的目錄里面了。那么這些實(shí)際上是在哪里配置的。這就涉及到nginx的一個重要配置文件nginx.conf了。
2)我們可以看到nginx文件夾內(nèi)有一個conf文件夾,其中有好幾個文件,其他先不管,我們打開nginx.conf,可以看到一段:

201631895212884.png (525×365)

這段代碼在server里面,相當(dāng)于一個代理服務(wù)器,當(dāng)然可以配置多個。下面我們仔細(xì)來分析一下:listen:表示當(dāng)前的代理服務(wù)器監(jiān)聽的端口,默認(rèn)的是監(jiān)聽80端口。注意,如果我們配置了多個server,這個listen要配置不一樣,不然就不能確定轉(zhuǎn)到哪里去了。server_name:表示監(jiān)聽到之后需要轉(zhuǎn)到哪里去,這時我們直接轉(zhuǎn)到本地,這時是直接到nginx文件夾內(nèi)。location:表示匹配的路徑,這時配置了/表示所有請求都被匹配到這里root:里面配置了root這時表示當(dāng)匹配這個請求的路徑時,將會在這個文件夾內(nèi)尋找相應(yīng)的文件,這里對我們之后的靜態(tài)文件伺服很有用。index:當(dāng)沒有指定主頁時,默認(rèn)會選擇這個指定的文件,它可以有多個,并按順序來加載,如果第一個不存在,則找第二個,依此類推。下面的error_page是代表錯誤的頁面,這里我們暫時不用,先不管它。
那我們知道了具體的配置了,怎么讓它訪問localhost時轉(zhuǎn)到tomcat時。實(shí)際上就修改兩個地方:

server_name localhost:8080;  
location / {  proxy_pass http://localhost:8080} 

我們就修改了上面兩個地方,我的tomcat在8080端口,可以根據(jù)自己的需要修改。這里有一個新元素proxy_pass,它表示代理路徑,相當(dāng)于轉(zhuǎn)發(fā),而不像之前說的root必須指定一個文件夾。此時我們修改了文件,是不是就意思著必須先關(guān)了nginx再重新啟動了,其實(shí)不必,nginx可以重新加載文件的。我們直接運(yùn)行:nginx -s reload  
高興得太早了,我們發(fā)現(xiàn)有一個錯誤:

201631895239427.png (648×57)

什么來的,45行發(fā)現(xiàn)錯誤,不希望在那一行找到},于是我們仔細(xì)找,發(fā)現(xiàn)我們加入的proxy_pass很奇怪,沒有;號結(jié)尾,這就是問題了,直接修改,然后再運(yùn)行一下,發(fā)現(xiàn)沒錯誤,OK了。如果不想直接加載,而只是想看看自己的配置文件有沒有問題,可以直接輸入:nginx -t 
這可以檢查配置文件中是否有錯。 下面我們所有的修改都假設(shè)我們修改完成后運(yùn)行了nginx -s reload進(jìn)行重新加載配置文件,請注意。
一切沒問題了,然后我們再重新打開http://localhost,我們看到下面的頁面:

201631895256033.png (1166×426)

這時,我們發(fā)現(xiàn)它并不是剛才的welcome頁面了,而是tomcat的管理頁面了,不管我們點(diǎn)擊什么鏈接都是沒問題的,相當(dāng)于直接訪問http://localhost:8080一樣。
3)上面我們直接試了一個小例子,讓nginx進(jìn)行轉(zhuǎn)發(fā),即所謂的反向代理。但實(shí)際上我們的需求不會是這樣的,我們需要分文件類型來進(jìn)行過濾,比如jsp直接給tomcat處理,因?yàn)閚ginx并不是servlet容器,沒辦法處理JSP,而html,js,css這些不需要處理的,直接給nginx進(jìn)行緩存。下面我們來進(jìn)行一下配置,讓JSP頁面直接給tomcat,而html,png等一些圖片和JS等直接給nginx進(jìn)行緩存。這時最主要用的還是location這個元素,并且涉及到一部分正則,但不難:

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

  我們先要去掉之前配的location /,避免全部請求被攔截了。然后我們再來看看http://localhost

201631895317331.png (819×146)

當(dāng)我們不指定jsp頁面的時候,它會出現(xiàn)找不到,因?yàn)?,此時并沒有相應(yīng)的location匹配,所以就會有404錯誤,這時就跳到了nginx自定義的error頁面去了。而當(dāng)我們用http://localhost/index.jsp去訪問時,我們看到了熟悉的頁面:

201631895336204.png (1154×394)

而且圖片那些都顯示正常,因?yàn)閳D片是png的,所以直接在tomcat/webapps/ROOT目錄下直接查找,當(dāng)然,如果我們點(diǎn)擊Manager Application HOW-TO這個鏈接,我們發(fā)現(xiàn):

201631895355232.png (872×152)

它還是找不到,為什么呢?因?yàn)檫@是個html頁面,但它并不在ROOT目錄下,而是在docs目錄下,但當(dāng)我們匹配html時,我們卻到ROOT目錄下去找,所以還是找不到這個頁面。
一般情況下,如果我們需要用nginx來進(jìn)行靜態(tài)文件伺服,一般都會把所有靜態(tài)文件,html,htm,js,css等都放在同一個文件夾下,這樣就不會有tomcat這樣的情況了,因?yàn)閠omcat下的是屬于不同的項(xiàng)目,這個我們就沒辦法了。
3)有些人會說,這些都只會找一臺服務(wù)器,但如果我們想在一臺服務(wù)器掛了的時候,自動去找另外一臺,這怎么辦?這實(shí)際上nginx都考慮到了。這時,我們之前用的proxy_pass就有大用途了。我們把之前的第一個例子,即全部都代理的修改一下:最后修改如下:

upstream local_tomcat {  server localhost:8080;}  
server{    location / {      proxy_pass http://local_tomcat;    }  
  ##......其他省略
}  
upstream local_tomcat {  server localhost:8080;} 
server{    location / {      proxy_pass http://local_tomcat;    } 
  #......其他省略
} 

  我們在server外添加了一個upstream,而直接在proxy_pass里面直接用http://+upstream的名稱來使用。我們還是直接來http://localhost,還是和第一個一樣的效果,所有鏈接都沒問題,說明我們配置正確。upstream中的server元素必須要注意,不能加http://,但proxy_pass中必須加。我們剛才說可以在一個服務(wù)器掛了的情況下連到另外一個,那怎么弄呢?其實(shí)很簡單,在upstream中的local_tomcat中配置多一個server。比如我現(xiàn)在弄多一個jetty,端口在9999,所以我們配置如下:

upstream local_tomcat {  server localhost:8080;  server localhost:9999;}  
upstream local_tomcat {  server localhost:8080;  server localhost:9999;} 

  此時,我們關(guān)閉tomcat,而只開jetty。我們來運(yùn)行http://localhost看看效果:  我們看到它請求到了jetty的頁面,但由于jetty的機(jī)制,這時沒有顯示jetty主頁,這個我們先不管。但我們的在一個服務(wù)器掛的情況下自動使用另外一個的功能實(shí)現(xiàn)了。
但有時我們就不想它掛的時候訪問另外一個,而只是希望一個服務(wù)器訪問的機(jī)會比另外一個大,這個可以在server最后加上一個weight=數(shù)字來指定,數(shù)字越大,表明請求到的機(jī)會越大。 

upstream local_tomcat {  server localhost:8080 weight=1;  server localhost:9999 weight=5;}  
upstream local_tomcat {  server localhost:8080 weight=1;  server localhost:9999 weight=5;} 

  這時我們給了jetty一個更高的權(quán)值,讓它更有機(jī)會訪問到,實(shí)際上當(dāng)我們刷新http://localhost訪問的時候發(fā)現(xiàn)jetty訪問機(jī)率大很多,tomcat幾乎沒機(jī)會訪問,一般情況下,如果我們必須這樣用,不要相關(guān)太大,以免一個服務(wù)器負(fù)載太大。當(dāng)然,server還有一些其他的元素,比如down表示暫時不用到該服務(wù)器等等。這些可以參考nginx的wiki。也許寫了一大堆,有人會有問題,那nginx怎么關(guān)閉呢?這倒是個問題,其實(shí)直接運(yùn)行nginx -s stop就可以關(guān)閉了。

相關(guān)文章

  • nginx 內(nèi)置變量詳解及隔離進(jìn)行簡單的攔截

    nginx 內(nèi)置變量詳解及隔離進(jìn)行簡單的攔截

    這篇文章主要介紹了nginx 隔離進(jìn)行簡單的攔截詳解的相關(guān)資料,這里對nginx內(nèi)置變量進(jìn)行了簡單的介紹并對隔離攔截進(jìn)行了詳解, 需要的朋友可以參考下
    2016-12-12
  • nginx上傳文件限制的操作步驟

    nginx上傳文件限制的操作步驟

    Nginx限制文件大小可以通過?client_max_body_size?指令來設(shè)置,該指令通常在?http、server?或location?塊中設(shè)置,如果不設(shè)置,默認(rèn)上傳大小為1M,這篇文章主要介紹了nginx上傳文件限制,需要的朋友可以參考下
    2024-08-08
  • Nginx Lua Waf 插件一鍵部署的操作示例

    Nginx Lua Waf 插件一鍵部署的操作示例

    這篇文章主要介紹了Nginx Lua Waf 插件一鍵部署的操作示例,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-07-07
  • Nginx反向代理及負(fù)載均衡如何實(shí)現(xiàn)(基于linux)

    Nginx反向代理及負(fù)載均衡如何實(shí)現(xiàn)(基于linux)

    這篇文章主要介紹了Nginx反向代理及負(fù)載均衡如何實(shí)現(xiàn)(基于linux),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-09-09
  • nginx實(shí)現(xiàn)ip限流的具體示例

    nginx實(shí)現(xiàn)ip限流的具體示例

    限流的方式油很多種,本文主要介紹了nginx實(shí)現(xiàn)ip限流的具體示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-07-07
  • Forever+nginx部署Node站點(diǎn)的方法示例

    Forever+nginx部署Node站點(diǎn)的方法示例

    這篇文章主要介紹了Forever+nginx部署Node站點(diǎn)的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • nginx代理多次302的解決方法(nginx Follow 302)

    nginx代理多次302的解決方法(nginx Follow 302)

    這篇文章主要介紹了nginx代理多次302的解決方法(nginx Follow 302),詳細(xì)的介紹了解決方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • nginx配置ssl雙向驗(yàn)證的方法

    nginx配置ssl雙向驗(yàn)證的方法

    這篇文章主要介紹了nginx配置ssl雙向驗(yàn)證的方法,需要的朋友可以參考下
    2014-11-11
  • 深入解析nginx路由location匹配規(guī)則及其優(yōu)先級

    深入解析nginx路由location匹配規(guī)則及其優(yōu)先級

    Nginx是一款高性能的Web服務(wù)器和反向代理服務(wù)器,它的路由功能是通過location指令來實(shí)現(xiàn)的,location指令用于匹配請求的URL,并將請求轉(zhuǎn)發(fā)到相應(yīng)的處理程序或靜態(tài)文件,需要的朋友可以參考下
    2023-10-10
  • 基于Nginx實(shí)現(xiàn)HTTPS網(wǎng)站設(shè)置的步驟

    基于Nginx實(shí)現(xiàn)HTTPS網(wǎng)站設(shè)置的步驟

    本文主要介紹了Nginx實(shí)現(xiàn)HTTPS網(wǎng)站設(shè)置的步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08

最新評論