location功能:匹配的ngnix变量:$request_uri
 作用:定义url匹配模式,可以根据请求uri判断相应配置
 配置文件中一般有多个location,分别定义了不同的匹配模式,不同的uri根据匹配结果获取不同的配置。
 location的匹配模式:location的匹配都是前缀匹配。格式:
location [ 空格 | = | ~ | ~* | !~ | !~* ] /uri/ {}
分为3类:
精确模式:精确匹配(=)
前缀模式: 普通匹配(空格),非正则匹配(^~)
正则模式: 大小写敏感匹配(~),大小写不敏感匹配(~*),大小写敏感不匹配(!~),大小写不敏感不匹配(!~*)location匹配优先级:
先匹配精确模式,命中精确模式,直接返回。否则,继续匹配前缀模式。
前缀模式中使用最大前缀原则,选出匹配普通匹配(空格)或非正则匹配(^~)的最长location。
若最长前缀location是非正则匹配(^~),则返回该最长前缀location。否则,还需要继续匹配正则模式。
正则模式的原则是按照正则location定义顺序匹配,第一个匹配的location为正则模式结果。
若正则模式匹配成功,返回正则模式结果。否则,返回前缀模式中的最长前缀location。
在nginx版本0.7.1 - 0.8.41中,若前缀模式的最长前缀location精确匹配uri,直接返回最长前缀location。if 精确匹配结果
 return 精确匹配结果
 最长前缀结果 = longest: 普通匹配(空格) or 非正则匹配(^~)
 if 最长前缀结果 属于 非正则匹配(^~)
 return 最长前缀结果
 if 版本 属于 0.7.1 - 0.8.41 and 最长前缀结果 == uri:
 return 最长前缀结果
 首个正则结果 = first: 大小写敏感匹配(~) or 大小写不敏感匹配(~) or 大小写敏感不匹配(!~) or 大小写不敏感不匹配(!~)
 if 首个正则结果:
 return 首个正则结果
 else:
 return 最长前缀结果示例
location / {}
前缀模式,匹配所有uri,最短匹配
 所以,这个location为兜底location。即当其他所有location都不匹配时,命中这个location。location = / {
 [ 配置 A ]
 }location / {
 [ 配置 B ]
 }location /documents/ {
 [ 配置 C ]
 }location ^~ /images/ {
 [ 配置 D ]
 }location ~* .(gif|jpg|jpeg)$ {
 [ 配置 E ]
 }uri:“/”
 精确匹配:配置 A
 uri:“/index.html”
 兜底匹配:配置 B
 uri:“/documents/document.html”
 最长location匹配:配置 C
 uri:“/images/1.gif”
 非正则匹配:配置 D
 uri:“/documents/1.jpg”
 正则匹配:配置 E
 内部location(@)内部location不能被外部 Client 所访问,只能用于重定向。它不能被嵌套,也不能包含嵌套的location。格式为:
location @name {}
示例:
error_page 404 = @fallback
 location @fallback {
 }特殊处理location
若前缀模式location以斜杠(/)结尾,并且请求设置由proxy_pass, fastcgi_pass, uwsgi_pass, scgi_pass或 memcached_pass等处理器处理,则使用该处理器处理。
 但对于末尾不带斜杠的uri,这时会返回301并重定向到带斜杠的uri,继而匹配该location。location /user/ {
 proxy_pass http://user.example.com;
 }uri: /user/
 转发到ttp://user.example.com
 uri:/user
 返回301,并重定向到/user/
 如果不希望自动重定向,可以定义两个location,设置不同配置:location /user/ {
 proxy_pass http://user.example.com;
 }
 location = /user {
 proxy_pass http://login.example.com;
 }