Nginx的try_files指令和命名location使用實例


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,一般只用於內部重定向請求。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM