玩转Nginx location配置

原文链接:https://mp.weixin.qq.com/s/kaEtfmX9bVdKfCVY6gbOsQ
建议点击原文链接查看
nginx是一个跨平台的web服务器, 基于事件驱动的架构并发处理百万级别连接, 独有的sendfile调用。

为什么是nginx?

因为他更快, 高扩展性, 高可靠性, 低内存消耗, 单机支持10万以上的并发连接, 热部署, 最自由的BSD许可协议。

nginx常用命令

/usr/local/webserver/nginx/sbin/nginx -v # 查看 Nginx 版本
/usr/local/webserver/nginx/sbin/nginx # 启动 Nginx
/usr/local/webserver/nginx/sbin/nginx -t # 检查配置文件正确性
/usr/local/webserver/nginx/sbin/nginx -s reload # 重新载入配置文件
/usr/local/webserver/nginx/sbin/nginx -s reopen # 重启 Nginx
/usr/local/webserver/nginx/sbin/nginx -s stop # 停止 Nginx
nginx配置

部署nginx后,项目中最常配置的location,总结 location 配置规则:

语法规则:location [=||*|^~] /uri/ { … }

正则location 还是与顺序有关的, 正则 location 匹配让步普通 location 的严格精确匹配结果,正则 location 匹配覆盖普通 location 的最大前缀匹配结果.

搜索优先级:

精确匹配[=] > 字符串匹配( 长 > 短 [ 注: ^~ 匹配则停止匹配 ]) > 正则匹配( 上 > 下 )
使用优先级:

精确匹配[=] > (^~) > 正则匹配( 上 > 下 )>字符串(长 > 端)
= 开头表示精确匹配

^~ 开头表示uri以某个常规字符串开头,理解为匹配 url路径即可 #nginx不对url做编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配到(注意是空格) #以xx开头
开头表示区分大小写的正则匹配 #以xx结尾

~* 开头表示不区分大小写的正则匹配 #以xx结尾

!和!*分别为区分大小写不匹配及不区分大小写不匹配 的正则

/ 通用匹配,任何请求都会匹配到。

例子,有如下匹配规则:

location = / {

精确匹配 / ,主机名后面不能带任何字符串

[ configuration A ]
}

location / {

因为所有的地址都以 / 开头,所以这条规则将匹配到所有请求

但是正则和最长字符串会优先匹配

[ configuration B ]
}

location /documents/ {

匹配任何以 /documents/ 开头的地址,匹配符合以后,还要继续往下搜索

只有后面的正则表达式没有匹配到时,这一条才会采用这一条

[ configuration C ]
}

location ~ /documents/Abc {

匹配任何以 /documents/ 开头的地址,匹配符合以后,还要继续往下搜索

只有后面的正则表达式没有匹配到时,这一条才会采用这一条

[ configuration CC ]
}

location ^~ /images/ {

匹配任何以 /images/ 开头的地址,匹配符合以后,停止往下搜索正则,采用这一条。

[ configuration D ]
}

location ~* .(gif|jpg|jpeg)$ {

匹配所有以 gif,jpg或jpeg 结尾的请求

然而,所有请求 /images/ 下的图片会被 config D 处理,因为 ^~ 到达不了这一条正则

[ configuration E ]
}

location /images/ {

字符匹配到 /images/,继续往下,会发现 ^~ 存在

[ configuration F ]
}

location /images/abc {

最长字符匹配到 /images/abc,继续往下,会发现 ^~ 存在

F与G的放置顺序是没有关系的

[ configuration G ]
}

location ~ /images/abc/ {

只有去掉 config D 才有效:先最长匹配 config G 开头的地址,继续往下搜索,匹配到这一条正则,采用

[ configuration H ]
}

location ~* /js/.*/.js
常用正则

. :匹配除换行符以外的任意字符

? :重复0次或1次

  • :重复1次或更多次
  • :重复0次或更多次

\d :匹配数字

^ :匹配字符串的开始

$ :匹配字符串的介绍

{n} :重复n次

{n,} :重复n次或更多次

[c] :匹配单个字符c

[a-z] :匹配a-z小写字母的任意一个

小括号()之间匹配的内容,可以在后面通过$1来引用,$2表示的是前面第二个()里的内容。正则里面容易让人困惑的是\转义特殊字符。

posted @ 2020-04-21 11:34  自动测试交流圈  阅读(374)  评论(0)    收藏  举报