匹配规则:

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标记则在本条规则匹配完成后,终止匹配。