我正在尝试为静态内容设置不同的limit_req区域。
location ^~ /img {
limit_req zone=static burst=60 nodelay;
}
location ^~ /logos {
limit_req zone=static burst=60 nodelay;
}
location ^~ /js {
limit_req zone=static burst=60 nodelay;
}
location ^~ /plugin {
limit_req zone=static burst=60 nodelay;
}
location / {
limit_req zone=protected burst=5 nodelay;
}
这工作正常,但我想将这些位置压缩到一个正则表达式中:
location ^~ /(img|logos|js|plugin) {
limit_req zone=static burst=60 nodelay;
}
试过这个,但它不起作用。仅适用于不带 ^ 的 ~,然后匹配位置/,将区域设置回 protected
.^~ 只适用于文字吗?还有其他方法可以干净地实现这一目标吗?
根据nginx文档
以下位置在具有proxy_pass的位置之前定义,它与静态下 js 和 css 文件的请求相匹配。此位置块用于您希望在站点中允许的不同扩展程序。
location ~* .(js|css|png|jpg|jpeg|gif|ico)$ {
limit_req zone=static burst=60 nodelay;
log_not_found off;
}
或者,您可以使用它我认为这应该可以正常工作
location ~ ^/(img|logos|js|plugin)/ {
root /project_root_path;
limit_req zone=static burst=60 nodelay;
}