nginx.conf----location匹配规则

指令作用:

    匹配指定的请求URI

语法:

  location [=|~|~*|^~|@] /uri/ {configuration}

匹配命令:

  ~  表示执行一个正则匹配,区分大小写

  ~*  表示执行一个正则匹配,不区分大小写

  ^~ 表示普通字符匹配,如果该选项匹配,只匹配该选项,不匹配其他。一般用来匹配目录

  = 进行普通字符精确匹配

无前缀 用于普通字符串

  @ 定义一个命名的location,使用在内部定向时,例如error_page,try_files

# 匹配字符串分为两种:普通字符串、正则表达式。

# ~和~* 用于正则表达式,其他前缀和无任何前缀都用于普通字符串。

# 正则表达式会根据匹配顺序,匹配到第一个正则表达式后停止搜索。

# 普通字符串匹配则无视顺序,只会选择最精确的匹配。

优先级:

  1、先匹配精确普通字符串,将最精确的匹配暂时存储;如果没有匹配上,进行普通字符串匹配,若匹配多个,按最长匹配,之后是^~匹配;

  2、然后按照配置文件中的声明顺序进行正则表达式匹配,只要匹配到一个正则表达式,则停止匹配,取正则表达式为匹配结果;

  3、如果所有正则表达式都匹配不上,则取1中的结果;

  4、最后匹配“/”,如果普通字符串和正则表达式都匹配不上,则报404 NOT FOUND。

  "=" > "完整路径" > "^~" > "~/~*" > "/"

示例:

location = /{ #只匹配“/”

}

location / { #匹配任何请求,所有URI都是以“/”开始;更长字符匹配或正则表达式匹配会优先

}

location ^~ /Directory/ { #匹配任何以/Directory/ 开始的请求,并停止匹配其他location

}

location ~* .(gif|jpg|jpeg)$ { #匹配以gif、jpg、jpeg结尾的请求;但是遇到^~由它处理

}

location /index/ { #以/index/开头的请求,如果链接的状态为404。则会匹配到@index_error

error_page 404 @index_error;

}

location @index_error {

...

}

常用配置指令:alias、root、proxy_pass

1、alias

别名配置,用于访问文件系统,在匹配到URI后,指向alias配置的路径,如:

location /test/ {

alias /usr/local/;

}

#请求/test/file,返回文件/usr/local/file

正则表达式的location中的alias,会使用正则表达式的值

location ~* /test/(.+\.(gif|png|jpeg){

alias /usr/local/test1/$1;

}

eg:/test/love.gif转化为/usr/local/test1/love.gif

2、root

根路径配置,用于访问文件系统,在匹配到URI后,指向root配置的路径,并把请求路径附加到其后,如:

location /test/ {

root /usr/local/;

}

#请求/test/file,将会返回文件/usr/local/test/file。

3、proxy_pass

代理配置,用于代理请求,匹配到URI后,转发请求到proxy_pass配置的URL。

location /test/ {

proxy_pass http://192.168.1.111:8089/;

}

eg:/test/hello转化到http://192.168.1.111:8089/hello

#如果proxy_pass配置了“/”则不附加location的URI,

没有配置“/”,则会附加。