location
指令
location [ = | ~ | ~* | ^~ ] uri {}
不讨论 location @name {} 形式
官方文档有如下描述:
A location can either be defined by a prefix string, or by a regular expression.
Regular expressions are specified with the preceding~*
modifier (for case-insensitive matching), or the~
modifier (for case-sensitive matching).
To find location matching a given request,
- nginx first checks locations defined using the prefix strings (prefix locations). Among them, the location with the longest matching prefix is selected and remembered.
- Then regular expressions are checked, in the order of their appearance in the configuration file. The search of regular expressions terminates on the first match, and the corresponding configuration is used.
- If no match with a regular expression is found then the configuration of the prefix location remembered earlier is used.
If the longest matching prefix location has the
^~
modifier then regular expressions are not checked.
Also, using the=
modifier it is possible to define an exact match of URI and location. If an exact match is found, the search terminates.
location
指令由修饰符和匹配项组成,匹配项可以是 前缀字符串(prefix string,也就是仅从uri的开头匹配) 或者 正则表达式(regular expression,uri全局正则匹配),共有以下五种组合
prefix-string
前缀字符串匹配= prefix-string
精确匹配字符串,URI和此字符串完全相等~ regular-expression
大小写敏感的正则匹配~* regular-expression
大小写不敏感的正则匹配^~ prefix-string
前缀字符串匹配,当为prefix-string
和^~ prefix-string
两类匹配成功的最长项时起作用
注意查找匹配顺序,查找和使用的优先级并不一样:
- 精确匹配
= prefix-string
,成功则停止; - 匹配其他
prefix strings
,选中并记住所有匹配成功中的最长匹配(longest matching prefix);如果当前最长匹配有^~
修饰符,则停止; - 正则匹配
[~* | ~] regular expressions
,顺序为在配置文件中的出现顺序,成功则停止; - 使用第2步查找到的最长匹配项,否则404 Not Found。
测试
location / {return 200 '/\n';}location /images/avatars {return 200 '/images/avatars\n';}location = /images {return 200 '= /images\n';}# 注意是否是前缀匹配 **成功** 中的 **最长** 项目location ^~ /images {return 200 '^~ images\n';}location ~* \.(png|jpg)$ {return 200 '~* \.(png|jpg)\n';}
url | location | 顺序 |
---|---|---|
curl localhost | / | 1.2(/).3.4.=>2(/). |
curl localhost/x | / | 1.2(/).3.4.=>2(/). |
curl localhost/images | = /images | 1. |
curl localhost/images/me.jpg | ^~ images | 1. 2(^~ /images). |
curl localhost/images/avatars | /images/avatars | 1.2(/images/avatars).3.4.=>2(/images/avatars). |
curl localhost/images/avatars/me.jpg | ~* \.(png|jpg)$ | 1.2(/images/avatars).3. |
curl localhost/images/xxx/me.jpg | ^~ images | 1.2(^~ /images). |
References
- Regular expression syntax cheat sheet
- Nginx/Doc/Location
- Understanding Nginx Server and Location Block Selection Algorithms