原文链接: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表示的是前面第二个()里的内容。正则里面容易让人困惑的是\转义特殊字符。
byby 下期见!!
快来关注公众号【自动化测试交流圈】吧,下期内容更精彩哦!!
或直接加入微信【微信圈子】:入口->搜一搜->圈子:搜索【自动化测试交流圈】
943

被折叠的 条评论
为什么被折叠?



