前言
location 指令是 nginx 中最關鍵的指令之一,location 指令的功能是用來匹配不同的 URI 請求,進而對請求做不同的處理和響應,這其中較難理解的是多個 location 的匹配順序,本文會作為重點來解釋和說明。
開始之前先明確一些約定,我們輸入的網址叫做請求 URI,nginx 用請求 URI 與 location 中配置的 URI 做匹配。
nginx文件結構
首先我們先簡單了解 nginx 的文件結構,nginx 的 HTTP 配置主要包括三個區塊,結構如下:
Global: nginx 運行相關
Events: 與用戶的網絡連接相關
http
http Global: 代理,緩存,日志,以及第三方模塊的配置
server
server Global: 虛擬主機相關
location: 地址定向,數據緩存,應答控制,以及第三方模塊的配置
從上面展示的 nginx 結構中可以看出 location 屬於請求級別配置,這也是我們最常用的配置
語法詳解
語法規則: location [=|~|~*|^~] /uri/ { … }
-
=
開頭表示精確匹配 -
^~
開頭表示uri以某個常規字符串開頭,理解為匹配 url路徑即可。nginx不對url做編碼,因此請求為/static/20%/aa,可以被規則^~ /static/ /aa匹配到(注意是空格)。以xx開頭 -
~
開頭表示區分大小寫的正則匹配 以xx結尾 -
~*
開頭表示不區分大小寫的正則匹配 以xx結尾 -
!~
和!~*
分別為區分大小寫不匹配及不區分大小寫不匹配 的正則 -
/
通用匹配,任何請求都會匹配到。
location中的try_files
示例一
location / { try_files $uri $uri/ /index.php?$query_string; }
當用戶請求 http://localhost/example
時,這里的 $uri
就是 /example
。
try_files 會到硬盤里嘗試找這個文件。如果存在名為 /$root/example
(其中 $root
是項目代碼安裝目錄)的文件,就直接把這個文件的內容發送給用戶。
顯然,目錄中沒有叫 example 的文件。然后就看 $uri/
,增加了一個 /
,也就是看有沒有名為 /$root/example/
的目錄。
又找不到,就會 fall back 到 try_files 的最后一個選項 /index.php,發起一個內部 “子請求”,也就是相當於 nginx 發起一個 HTTP 請求到 http://localhost/index.php
示例二
loaction / { try_files $uri @apache } loaction @apache{ proxy_pass http://127.0.0.1:88 include aproxy.conf }
try_files方法讓Ngxin嘗試訪問后面得$uri鏈接,並進根據@apache配置進行內部重定向。
當然try_files也可以以錯誤代碼賦值,如
try_files /index.php = 404 @apache,則表示當嘗試訪問得文件返回404時,根據@apache配置項進行重定向。