因爲團隊在進行先後端分離,前端接管了Nginx和node層,在平常的工做中,跟Nginx打交道的時候挺多的。以前對location的匹配規則是隻知其一;不知其二的,爲了搞明白location是如何匹配的,查了些資料總結此文。但願能給你們帶來幫助。html
location [ = | ~ | ~* | ^~ ] uri { ... } location @name { ... }
語法規則很簡單,一個location
關鍵字,後面跟着可選的修飾符,後面是要匹配的字符,花括號中是要執行的操做。前端
=
表示精確匹配。只有請求的url路徑與後面的字符串徹底相等時,纔會命中。~
表示該規則是使用正則定義的,區分大小寫。~*
表示該規則是使用正則定義的,不區分大小寫。^~
表示若是該符號後面的字符是最佳匹配,採用該規則,再也不進行後續的查找。對請求的url序列化。例如,對%xx
等字符進行解碼,去除url中多個相連的/
,解析url中的.
,..
等。這一步是匹配的前置工做。node
location有兩種表示形式,一種是使用前綴字符,一種是使用正則。若是是正則的話,前面有~
或~*
修飾符。後端
具體的匹配過程以下:瀏覽器
首先先檢查使用前綴字符定義的location,選擇最長匹配的項並記錄下來。服務器
若是找到了精確匹配的location,也就是使用了=
修飾符的location,結束查找,使用它的配置。前後端分離
而後按順序查找使用正則定義的location,若是匹配則中止查找,使用它定義的配置。dom
若是沒有匹配的正則location,則使用前面記錄的最長匹配前綴字符location。測試
基於以上的匹配過程,咱們能夠獲得如下兩點啓示:網站
/
的話,可使用=
來定義location。接下來咱們以一個例子來具體說明一下匹配過程。
假如咱們有下面的一段配置文件:
location = / { [ configuration A ] } location / { [ configuration B ] } location /user/ { [ configuration C ] } location ^~ /images/ { [ configuration D ] } location ~* \.(gif|jpg|jpeg)$ { [ configuration E ] }
請求/
精準匹配A,再也不往下查找。
請求/index.html
匹配B。首先查找匹配的前綴字符,找到最長匹配是配置B,接着又按照順序查找匹配的正則。結果沒有找到,所以使用先前標記的最長匹配,即配置B。
請求/user/index.html
匹配C。首先找到最長匹配C,因爲後面沒有匹配的正則,因此使用最長匹配C。
請求/user/1.jpg
匹配E。首先進行前綴字符的查找,找到最長匹配項C,繼續進行正則查找,找到匹配項E。所以使用E。
請求/images/1.jpg
匹配D。首先進行前綴字符的查找,找到最長匹配D。可是,特殊的是它使用了^~
修飾符,再也不進行接下來的正則的匹配查找,所以使用D。這裏,若是沒有前面的修飾符,其實最終的匹配是E。你們能夠想想爲何。
請求/documents/about.html
匹配B。由於B表示任何以/
開頭的URL都匹配。在上面的配置中,只有B能知足,因此匹配B。
@用來定義一個命名location。主要用於內部重定向,不能用來處理正常的請求。其用法以下:
location / { try_files $uri $uri/ @custom } location @custom { # ...do something }
上例中,當嘗試訪問url找不到對應的文件就重定向到咱們自定義的命名location(此處爲custom)。
值得注意的是,命名location中不能再嵌套其它的命名location。
/
需不須要關於URL尾部的/
有三點也須要說明一下。第一點與location配置有關,其餘兩點無關。
/
都沒有影響。也就是說/user/
和/user
是同樣的。https://domain.com/
的形式,尾部有沒有/
都不會形成重定向。由於瀏覽器在發起請求的時候,默認加上了/
。雖然不少瀏覽器在地址欄裏也不會顯示/
。這一點,能夠訪問baidu驗證一下。https://domain.com/some-dir/
。尾部若是缺乏/
將致使重定向。由於根據約定,URL尾部的/
表示目錄,沒有/
表示文件。因此訪問/some-dir/
時,服務器會自動去該目錄下找對應的默認文件。若是訪問/some-dir
的話,服務器會先去找some-dir
文件,找不到的話會將some-dir
當成目錄,重定向到/some-dir/
,去該目錄下找默認文件。能夠去測試一下你的網站是否是這樣的。location的配置有兩種形式,前綴字符和正則。查找匹配的時候,先查找前綴字符,選擇最長匹配項,再查找正則。正則的優先級高於前綴字符。
正則的查找是按照在配置文件中的順序進行的。所以正則的順序很重要,建議越精細的放的越靠前。
使用=
精準匹配能夠加快查找的順序,若是根域名常常被訪問的話建議使用=
。