Nginx的try_files指令和命名location使用實例
阿新 • • 發佈:2018-02-20
解析 tor blank www. oca 字符 tar sch ofo
Nginx的配置語法靈活,可控制度非常高。在0.7以後的版本中加入了一個try_files指令,配合命名location,可以部分替代原本常用的rewrite配置方式,提高解析效率。
下面是一個使用實例(螺殼網V0.3的配置):
upstream tornado { server 127.0.0.1:8001; } server { server_name luokr.com; return 301 $scheme://www.luokr.com$request_uri; } server { listen 80; server_name www.luokr.com; root/var/www/www.luokr.com/V0.3/www; index index.html index.htm; try_files $uri @tornado; location @tornado { proxy_pass_header Server; proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Scheme $scheme; proxy_pass http://tornado; } }
可以在Github上查看螺殼網的源代碼。
try_files指令
語法:try_files file ... uri 或 try_files file ... = code
默認值:無
作用域:server location
其作用是按順序檢查文件是否存在,返回第一個找到的文件或文件夾(結尾加斜線表示為文件夾),如果所有的文件或文件夾都找不到,會進行一個內部重定向到最後一個參數。
需要註意的是,只有最後一個參數可以引起一個內部重定向,之前的參數只設置內部URI的指向。最後一個參數是回退URI且必須存在,否則會出現內部500錯誤。命名的location也可以使用在最後一個參數中。與rewrite指令不同,如果回退URI不是命名的location那麽$args不會自動保留,如果你想保留$args,則必須明確聲明。
location指令
語法:location [=|~|~*|^~|@] /uri/ { … }
默認值:無
作用域:server
location指令是用來為匹配的URI進行配置,URI即語法中的"/uri/",可以是字符串或正則表達式。但如果要使用正則表達式,則必須指定前綴。 [@] 即是命名location,一般只用於內部重定向請求。
Nginx的try_files指令和命名location使用實例