1. 程式人生 > 實用技巧 >Nginx 實踐:location 路徑匹配

Nginx 實踐:location 路徑匹配

1. 目標

nginx 反向代理,路徑對映的過程是什麼?如何配置路徑對映規則?

2.location 路徑匹配

2.1 匹配規則:

location 路徑正則匹配:

符號說明
~ 正則匹配,區分大小寫
~* 正則匹配,不區分大小寫
^~ 普通字元匹配,如果該選項匹配,則,只匹配改選項,不再向下匹配其他選項
= 普通字元匹配,精確匹配
@ 定義一個命名的 location,用於內部定向,例如 error_page,try_files

2.2 匹配優先順序:

路徑匹配,優先順序:(跟 location 的書寫順序關係不大)

  1. 精確匹配

    =字首的指令嚴格匹配這個查詢。

    如果找到,停止搜尋。

  2. 普通字元匹配

    所有剩下的常規字串,最長的匹配。

    如果這個匹配使用^〜字首,搜尋停止。

  3. 正則匹配

    正則表示式,在配置檔案中定義的順序,匹配到一個結果,搜尋停止;

  4. 預設匹配

    如果第3條規則產生匹配的話,結果被使用。

    否則,如同從第2條規則被使用。

2.3 舉例

通過一個例項,簡單說明一下匹配優先順序:

location=/{
#精確匹配/,主機名後面不能帶任何字串
[configurationA]
}

location/{
#因為所有的地址都以/開頭,所以這條規則將匹配到所有請求
#但是正則和最長字串會優先匹配
[configurationB]
}

location/documents/{
#匹配任何以/documents/開頭的地址,匹配符合以後,還要繼續往下搜尋
#只有後面的正則表示式沒有匹配到時,這一條才會採用這一條
[configurationC]
}

location~/documents/Abc{
#匹配任何以/documents/開頭的地址,匹配符合以後,還要繼續往下搜尋
#只有後面的正則表示式沒有匹配到時,這一條才會採用這一條
[configurationCC]
}

location^~/images/{
#匹配任何以/images/開頭的地址,匹配符合以後,停止往下搜尋正則,採用這一條。
[configurationD]
}

location~*\.(gif|jpg|jpeg)${
#匹配所有以gif,jpg或jpeg結尾的請求
#然而,所有請求/images/下的圖片會被configD處理,因為^~到達不了這一條正則
[configurationE]
}

location/images/{
#字元匹配到/images/,繼續往下,會發現^~存在
[configurationF]
}

location/images/abc{
#最長字元匹配到/images/abc,繼續往下,會發現^~存在
#F與G的放置順序是沒有關係的
[configurationG]
}

location~/images/abc/{
#只有去掉 config D 才有效:先最長匹配 config G 開頭的地址,繼續往下搜尋,匹配到這一條正則,採用
[configurationH]
}

location~*/js/.*/\.js

按照上面的location寫法,以下的匹配示例成立:

  1. /-> config A:

    精確完全匹配,即使/index.html也匹配不了

  2. /downloads/download.html-> config B:

    匹配B以後,往下沒有任何匹配,採用B

  3. /images/1.gif-> configuration D:

    匹配到F,往下匹配到D,停止往下

  4. /images/abc/def-> config D:

    最長匹配到G,往下匹配D,停止往下你可以看到 任何以/images/開頭的都會匹配到D並停止,FG寫在這裡是沒有任何意義的,H是永遠輪不到的,這裡只是為了說明匹配順序

  5. /documents/document.html-> config C:

    匹配到C,往下沒有任何匹配,採用C

  6. /documents/1.jpg-> configuration E:

    匹配到C,往下正則匹配到E

  7. /documents/Abc.jpg-> config CC:

    最長匹配到C,往下正則順序匹配到CC,不會往下到E