大家都知道, 但是很多人能了解到常用的location指令的優先級別是怎么樣的,這個也許知道的人就不多了吧. 先前記得有個國人說過一個nginx的“bug”(), 就是關于location配置不當造成的, 這其實并不是nginx的bug, 而是運維人員的對nginx配置location優先級別理解不很透徹造成的.
nginx官方已經指明了location指令說明:
syntax: location [ = | ~ | ~* | ^~ ] uri { ... }
location @name { ... }
default: —
context: server, location
讓我們先來理解下, nginx 規則處理請求是在對路徑匹配在URI規范化以后進行. 所謂規范化, 就是先將URI中形如“%XX”的編碼字符進行解碼, 再解析URI中的相對路徑“.”和“..”部分, 另外還可能會壓縮相鄰的兩個或多個斜線成為一個斜線:
= 開頭表示精確匹配, 必須完全吻合才會執行;
^~ 開頭表示uri以某個常規字符串開頭,理解為匹配 url 路徑即可, 如果最大前綴匹配的路徑以“^~”開始,那么nginx不再檢查正則表達式. nginx不對url做編碼,因此請求為/assets/20%/css.css,可以被規則^~ /assets/ /css.css匹配到(注意是空格);
~ 開頭表示區分大小寫的正則匹配;
~* 開頭表示不區分大小寫的正則匹配, 與~相反是大小寫同等對待的;
/ 通用匹配, 如果沒有其它匹配,任何請求都會匹配到.
優先級別基本可以這么認為:
(location =) > (location 完整路徑) > (location ^~ 路徑) > (location ~* 正則) > (location 路徑) > (/)
nginx虛擬host配置
server {
listen 80;
server_name www.xxx.my ;
root "D:/WWW/xxxx/public";
location / {
index index.html index.htm index.php;
#autoindex on;
try_files $uri $uri/ /index.php;
#去掉index.php入口文件
if (!-e $request_filename){
rewrite ^/(.*)$ /index.php/$1 last;
}
#權限認證auth
auth_basic "Restricted";#提示輸入用戶名密碼的提示語
auth_basic_user_file htpasswd;
}
location ~ \.php(.*)$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_split_path_info ^((?U).+\.php)(/?.+)$;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info;
include fastcgi_params;
}
}