8/19 初识nginx

URL地址匹配是Nginx配置中最灵活的部分 Location 支持正则表达式匹配,也支持条件匹配,用户可以通过location指令实现Nginx对动丶静态网页的过滤处理。

Nginx location 配置语法

location [ = | ~ | ~* | ^~ ] uri { … }
location @name { … }

location 配置可以有两种配置方法

前缀 + uri(字符串/正则表达式)
@ + name

前缀含义

=:精确匹配(必须全部相等)
~:大小写敏感
~*:忽略大小写
^~:只需匹配uri部分
@:内部服务跳转

Location 基础知识

location 是在 server 块中配置。
可以根据不同的 URI 使用不同的配置(location 中配置),来处理不同的请求。
location 是有顺序的,会被第一个匹配的location 处理。

Location 配置演示

=精确匹配

location = / { #规则 } # 则匹配到 http://www.example.com/ 这种请求。

~大小写敏感

location~ /Example/ { #规则 } #请求示例#http://www.example.com/Example/ [成功]#http://www.example.com/example/ [失败]

~*大小写忽略

location~* /Example/ { #规则 } # 则会忽略 uri 部分的大小写#http://www.example.com/Example/ [成功]#http://www.example.com/example/ [成功]

^~只匹配以 uri 开头

location ^~ /img/ { #规则 } #以 /img/ 开头的请求,都会匹配上#http://www.example.com/img/a.jpg [成功]#http://www.example.com/img/b.mp4 [成功]

@nginx内部跳转

location /img/ { error_page404@img_err; } location@img_err { # 规则 } #以 /img/ 开头的请求,如果链接的状态为 404。则会匹配到 @img_err 这条规则上。

规则分类

其中“~ ”和“”以及“!”和“!~”前缀表示正则location .

其他前缀(包括:“=”,“^~”和“@ ”)和无任何前缀的都属于普通location .

匹配规则

普通 location ”的匹配规则是“最大前缀.(特殊的是“=”和“^~”,前缀指令将严格匹配uri ,如果匹配,停止搜索.)
正则 location ”的匹配规则是“顺序匹配,且只要匹配到第一个就停止后面的匹配.
通用匹配 “/”最后匹配

先匹配普通 location ,再“考虑”匹配正则 location 。注意这里的“考虑”是“可能”的意思,也就是说匹配完“普通 location ”后,有的时候需要继续匹配“正则 location ”,有的时候则不需要继续匹配“正则 location ”。两种情况下,不需要继续匹配正则 location :( 1 )当普通 location 前面指定了“ ^~ ”,特别告诉 Nginx 本条普通 location 一旦匹配上,则不需要继续正则匹配;( 2 )当普通location 恰好严格匹配上,不是最大前缀匹配,则不再继续匹配正则.

总结:正则 location 匹配让步普通 location 的严格精确匹配结果;但覆盖普通 location 的最大前缀匹配结果.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值