匹配规则:
location 路径正则匹配规则:location [ = | ~ | ~* | ^~ | !~ | !~* ] /uri/{...}
* = 表示精确匹配
* ~ 表示区分大小写正则匹配
* ~* 表示不区分大小写正则匹配
* ^~ 表示URI以某个常规字符串开头
* !~ 表示区分大小写正则不匹配
* !~* 表示不区分大小写正则不匹配
* / 通用匹配,任何请求都会匹配到
匹配顺序
多个location配置的情况下匹配顺序为:
1、首先匹配 =
2、其次匹配 ^~
3、其次是按文件中顺序正则匹配
4、最后交给通用 / 匹配
当有匹配成功时候,停止匹配,按当前匹配规则处理请求。
常用规则
1、精确匹配
location = / {
proxy_pass http://127.0.0.1:9000;
}
将所有请求直接转发给服务器的9000端口。
2、处理静态文件
目录匹配
location ^~ /static/ {
root /data/app/static;
}
后缀匹配
location ~* \.(gif|jpg|jpeg|png|css|js|ico)$ {
root /data/app/static;
}
3、转发动态请求到后端应用服务器
将api开始的请求转发给后端8080端口
location /api {
proxy_pass http://127.0.0.1:8080;
}
rewrite指令
last 相当于apache里面的[L]标记,表示rewrite
break 本条规则匹配完成后,终止匹配,不再匹配后面的规则。
redirect 返回302临时重定向,浏览器地址会显示跳转后的URL地址。
permanent 返回301永久重定向,浏览器地址会显示跳转后的URL地址。
注意:
1、使用last和break实现URI重写,浏览器地址栏不变。
2、使用alias指令必须用last标记;使用proxy_pass指令时,需要使用break标记。
3、last标记在本条rewrite规则执行完毕后,会对其所在server{……}标签重新发起请求,而break标记则在本条规则匹配完成后,终止匹配。