在nginx的location和配置中location的順序沒有太大關係,與location表達式的類型有關。相同類型的表達式,字符串長的會優先匹配。html
如下是按優先級排列說明:nginx
配置項以下:正則表達式
location = / { # 僅僅匹配請求 / [ configuration A ] } location / { # 匹配全部以 / 開頭的請求。 # 可是若是有更長的同類型的表達式,則選擇更長的表達式。 # 若是有正則表達式能夠匹配,則優先匹配正則表達式。 [ configuration B ] } location /documents/ { # 匹配全部以 /documents/ 開頭的請求。 # 可是若是有更長的同類型的表達式,則選擇更長的表達式。 # 若是有正則表達式能夠匹配,則優先匹配正則表達式。 [ configuration C ] } location ^~ /images/ { # 匹配全部以 /images/ 開頭的表達式,若是匹配成功,則中止匹配查找。 # 因此,即使有符合的正則表達式location,也不會被使用 [ configuration D ] } location ~* \.(gif|jpg|jpeg)$ { # 匹配全部以 gif jpg jpeg結尾的請求。 # 可是 以 /images/開頭的請求,將使用 Configuration D [ configuration E ] }
請求匹配示例:spa
/ -> configuration A /index.html -> configuration B /documents/document.html -> configuration C /images/1.gif -> configuration D /documents/1.jpg -> configuration E
以上的匹配和在配置文件中定義的順序無關。code