最近为了提高系统性能,用nginx做了动静分离,期间遇到了一些问题,比如druid、swagger等第三方的插件提供自己的web静态资源(在自己的jar包中),这部分静态请求不想被nginx命中到静态文件中,于是研究了下location的命中规则。
总结location规则如下
格式 | 说明 | 优先级(值越小越优先匹配) | 备注 |
---|---|---|---|
location = /uri | =开头表示精确匹配,只有完全匹配上才能生效 | 1 | 匹配后不再匹配 |
location ^~ /uri | ^~ 开头对URL路径进行前缀匹配,并且在正则之前 | 2 | 匹配后继续匹配,匹配/uri 最长为准 |
location ~ pattern | ~开头表示区分大小写的正则匹配 | 3 | 匹配后不会再匹配,多个正则匹配和配置文件中的顺序有关 |
location ~* pattern | ~*开头表示不区分大小写的正则匹配 | 4 | 匹配后不会再匹配,多个正则匹配和配置文件中的顺序有关 |
location /uri | 不带任何修饰符,也表示前缀匹配,但是在正则匹配之后 | 5 | 匹配后继续匹配,匹配/uri 最长为准 |
location / | 通用匹配,任何未匹配到其它location的请求都会匹配到,相当于switch中的default | 6 | 通用匹配,所有没匹配上走这个分支 |
解决方法:
发现druid和swagger的uri都有一定规则的前缀,采用^~ /uri(在正则之前)和正则匹配来实现,这样druid和swagger的静态资源就不会被通用的正则匹配命中。
druid:
【location ^~ /druid/】
swagger:
【location ^~ /v2/api-docs】
【location ^~ /swagger-resources】
【location ^~ /configuration/】
【location ^~ /swagger-ui.html】
【location ^~ /webjars/】
通用静态文件:
【location ~ .*.(html|htm|gif|jpg|jpeg|bmp|png|ico|js|css)】