1. 语法介绍
# 1.假设请求 127.0.0.1/home
# 配置的location
location / {
root /opt/dist;
index ;
try_files $uri $uri/ /;
}
# 变量解释
try_files 固定语法
$uri 指代home文件(ip地址后面的路径,假如是127.0.0.1/index/,那就指代index/)
$uri/ 指代home文件夹
/ 向ip/ 地址发起请求
try_files $uri $uri/ /;
尝试解析下列2个文件/文件夹(自动分辨出,IP后面的路径是文件还是文件夹), $uri/$uri/,
如果解析到,返回第一个,
如果都没有解析到,向127.0.0.1/发起请求跳转(该路由必须真实,不然会报错)
2. 其他用法
2.1 实现内部跳转新的location
server {
listen 8000;
server_name 127.0.0.1;
location / {
root html;
index ;
# 检测根目录下文件和,如果存在正常显示,不存在就去跳转到@qwe
try_files / / @mq;
}
location @mq {
rewrite ^/(.*)$ ; # 跳转到百度页面
}
}
2.2 跳转指定文件
server {
listen 8000;
server_name 127.0.0.1;
location / {
root html;
index ;
# 去根目录查找 返回第一个找到的文件
try_files / / /;
}
2.3 将请求跳转到后端
upstream mydjango{
server 127.0.0.1:8001;
}
server {
listen 80;
server_name ;
location / {
root /opt/dist;
index ;
# 尝试解析文件/文件夹,解析不到,跳到后端处理
try_files $uri $uri/ @mq;
}
location @mq {
# 负载均衡的配置
proxy_pass http://mydjango;
}
}
3. 错误
- try_files 按顺序检查文件是否存在,返回第一个找到的文件,至少需要两个参数,但最后一个是内部重定向也就是说和rewrite效果一致。
- 可以用一个状态码 (404)作为最后一个参数。如果不注意会有死循环造成500错误。
- 错误代码
location ~.*\.(gif|jpg|jpeg|png)$ {
root /web/wwwroot;
try_files /static/$uri $uri;
}
原意图是访问/时,
先去检查/web/wwwroot/static/是否存在,
不存在就取/web/wwwroot/。
但由于最后一个参数是一个内部重定向,
所以并不会检查/web/wwwroot/是否存在,
只要第一个路径不存在,就会重定向,
然后再进入这个location造成死循环。
结果出现500 Internal Server Error
location ~.*\.(gif|jpg|jpeg|png)$ {
root /web/wwwroot;
try_files /static/$uri $uri 404;
}
这样才会先检查/web/wwwroot/static/是否存在,
不存在就/web/wwwroot/
再不存在则返回404 not found