大佬教程收集整理的这篇文章主要介绍了nginx基于一个“位置”中的URI阻止IP,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
目前有一个位置/
LOCATIOn / {
root /var/www/docs;
proxy_pass http://BACkend;
proxy_buffering on;
proxy_buffer_size 64k;
proxy_buffers 256 64k;
}
需要通过IP过滤.
理想情况下,为了减少位置中相同指令的重复次数,我想在位置块内执行测试
LOCATIOn / {
if ($uri ~ '^/(abc|def|ghi)') {
allow 10.0.0.0/8;
allow 1.2.3.4;
deny all;
}
root /var/www/docs;
proxy_pass http://BACkend;
proxy_buffering on;
proxy_buffer_size 64k;
proxy_buffers 256 64k;
}
不幸的是,似乎allow / deny指令不能在if块中使用.
"allow" directive is not allowed here in /etc/Nginx/sites-enabled/mysite:20
是否有一种优雅的方式来执行测试而不重复位置块?
(喜欢
LOCATIOn ~ /(abc|def|ghi) {
allow 10.0.0.0/8;
allow 1.2.3.4;
deny all;
... 5 other lines root,proxy...
}
LOCATIOn / {
... 5 other lines root,proxy...
}
)
但是可以使位置块的内容重复性降低.这里的关键是一个命名的位置块,它包含root和proxy _…指令.
例如:
LOCATIOn / {
try_files $uri @proxy;
}
LOCATIOn ~ /(abc|def|ghi) {
allow 10.0.0.0/8;
allow 1.2.3.4;
deny all;
try_files $uri @proxy;
}
LOCATIOn @proxy {
root /var/www/docs;
proxy_pass http://BACkend;
proxy_buffering on;
proxy_buffer_size 64k;
proxy_buffers 256 64k;
}
甚至可能更好的是将根指令放在所有位置块之外.
以上是大佬教程为你收集整理的nginx基于一个“位置”中的URI阻止IP全部内容,希望文章能够帮你解决nginx基于一个“位置”中的URI阻止IP所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。