nginx的location配置詳解

2021-07-29 15:12:17 字數 1926 閱讀 4326

語法規則: location [=|~|~*|^~] /uri/

= 開頭表示精確匹配

^~ 開頭表示uri以某個常規字串開頭,理解為匹配 url路徑即可。nginx不對url做編碼,因此請求為/static/20%/aa,可以被規則^~ /static/ /aa匹配到(注意是空格)。 ~ 

開頭表示區分大小寫的正則匹配

~*  

開頭表示不區分大小寫的正則匹配 !~

和!~*分別為區分大小寫

不匹配及不區分大小寫

不匹配的正則 / 

通用匹配,任何請求都會匹配到。

多個location配置的情況下匹配順序為(參考資料而來,還未實際驗證,試試就知道了,不必拘泥,僅供參考):

首先匹配 =,其次匹配^~, 其次是按檔案中順序的正則匹配,最後是交給 / 通用匹配。當有匹配成功時候,停止匹配,按當前匹配規則處理請求。

例子,有如下匹配規則:

那麼產生的效果如下:

訪問根目錄/, 比如http://localhost/ 將匹配規則a

訪問 http://localhost/login 將匹配規則b,http://localhost/register 則匹配規則h

訪問 http://localhost/static/a.html 將匹配規則c

訪問 http://localhost/a.gif, http://localhost/b.jpg 將匹配規則d和規則e,但是規則d順序優先,規則e不起作用,而 http://localhost/static/c.png 則優先匹配到 規則c

訪問 http://localhost/a.png 則匹配規則e, 而不會匹配規則d,因為規則e不區分大小寫。

訪問 http://localhost/a.xhtml 不會匹配規則f和規則g,http://localhost/a.xhtml不會匹配規則g,因為不區分大小寫。規則f,規則g屬於排除法,符合匹配規則但是不會匹配到,所以想想看實際應用中**會用到。

訪問 http://localhost/category/id/1111 則最終匹配到規則h,因為以上規則都不匹配,這個時候應該是nginx**請求給後端應用伺服器,比如fastcgi(php),tomcat(jsp),nginx作為方向**伺服器存在。

所以實際使用中,通常至少有三個匹配規則定義,如下:

[plain]view plain

copy

#直接匹配**根,通過網域名稱訪問**首頁比較頻繁,使用這個會加速處理,官網如是說。  

#這裡是直接**給後端應用伺服器了,也可以是乙個靜態首頁  

# 第乙個必選規則  

location = /   

# 第二個必選規則是處理靜態檔案請求,這是nginx作為http伺服器的強項  

# 有兩種配置模式,目錄匹配或字尾匹配,任選其一或搭配使用  

#第三個規則就是通用規則,用來**動態請求到後端應用伺服器  

#非靜態檔案請求就預設是動態請求,自己根據實際把握  

#畢竟目前的一些框架的流行,帶.php,.jsp字尾的情況很少了  

location /  

Nginx學習(二) location的相關配置

從這一篇部落格開始,正式介紹nginx的一些使用,這一篇會總結一下虛擬主機和location的相關配置。參考過很多部落格的內容,但是關於nginx中location的配置總結的很全的並沒有多少,這裡根據官網來進行簡單總結。所謂的虛擬主機,其實就是在一套伺服器上構建多個主機,這些主機是虛擬出來的,這個...

nginx的location配置詳解

語法規則 location uri 開頭表示精確匹配 開頭表示uri以某個常規字串開頭,理解為匹配 url路徑即可。nginx不對url做編碼,因此請求為 static 20 aa,可以被規則 static aa匹配到 注意是空格 開頭表示區分大小寫的正則匹配 開頭表示不區分大小寫的正則匹配 和 分...

nginx的location規則(一)

nginx的url配置是使用nginx最基本功能。nginx作為伺服器,它可以接收請求,處理請求,都是基於客戶端url訪問。掌握url的配置要了解配置的幾個指令。熟悉每個匹配模式的特點。之前對於nginx的location匹配規則,我是一塌糊塗,最近認真學了一下,稍微清晰一點了,先記錄下來,方便以後...