4 Nginx的Location区段的功能和配置使用
1 Location区段
Location区段,通过指定模式来与客户端请求的URI相匹配,基本语法如下:
location [=|~|~*|^~|@] pattern{……}
1.1没有修饰符
没有修饰符 表示:必须以指定模式开始,如:
server { server_name sishuok.com; location /abc { …… } } |
那么,如下是对的:
http://sishuok.com/abc
http://sishuok.com/abc?p1=11&p2=22
http://sishuok.com/abc/
http://sishuok.com/abcde
1.2 “=” 修饰符
= 表示:必须与指定的模式精确匹配,如:
server { server_name sishuok.com; location = /abc { …… } } |
那么,如下是对的:
http://sishuok.com/abc
http://sishuok.com/abc?p1=11&p2=22
如下是错的:
http://sishuok.com/abc/
http://sishuok.com/abcde
1.3“~” 修饰符
~ 表示:指定的正则表达式要区分大小写,如:
server { server_name sishuok.com; location ~ ^/abc$ { …… } } |
那么,如下是对的:
http://sishuok.com/abc
http://sishuok.com/abc?p1=11&p2=22
如下是错的:
http://sishuok.com/ABC
http://sishuok.com/abc/
http://sishuok.com/abcde
1.4” ~*” 修饰符
~* 表示:指定的正则表达式不区分大小写,如:
server { server_name sishuok.com; location ~* ^/abc$ { …… } } |
那么,如下是对的:
http://sishuok.com/abc
http://sishuok.com/ABC
http://sishuok.com/abc?p1=11&p2=22
如下是错的:
http://sishuok.com/abc/
http://sishuok.com/abcde
1.5” ^~” 修饰符
^~ 类似于无修饰符的行为,也是以指定模式开始,不同的是,如果模式匹配,那么就停止搜索其他模式了。
1.6” @” 修饰符
@ :定义命名location区段,这些区段客户段不能访问,只可以由内部产生的请求来访问,如try_files或error_page等
2查找顺序和优先级
1:带有“=“的精确匹配优先
2:没有修饰符的精确匹配
3:正则表达式按照他们在配置文件中定义的顺序
4:带有“^~”修饰符的,开头匹配
5:带有“~”或“~*”修饰符的,如果正则表达式与URI匹配
6:没有修饰符的,如果指定字符串与URI开头匹配
3 Location区段匹配示例
3.1 实例A
location = / {
# 只匹配 / 的查询.
[ configuration A ]
}
请求的处理如下例:
■/ →configuration A
3.2 实例B
location / {
# 匹配任何以 / 开始的查询,但是正则表达式与一些较长的字符串将被首先匹配。
[ configuration B ]
}
请求的处理如下例:
■/documents/document.html → configuration B
3.3 实例C
location ^~ /images/ {
# 匹配任何以 /images/ 开始的查询并且停止搜索,不检查正则表达式。
[ configuration C ]
}
请求的处理如下例:
■/images/1.gif →configuration C
3.4 实例D
location ~* \.(gif|jpg|jpeg)$ {
# 匹配任何以gif, jpg, or jpeg结尾的文件,但是所有 /images/ 目录的请求将在Configuration C中处
理。
[ configuration D ]
}
请求的处理如下例:
■/documents/1.jpg → configuration D