本配备:

http {
......
登录后复造
登录后复造
limit_conn_zone $binary_remote_addr zone=one:10m;
limit_req_zone $binary_remote_addr zone=fifa:10m rate=5r/s;
登录后复造
......
server {
......
limit_conn one 5;
limit_req zone=fifa burst=100;
......
}}
登录后复造
登录后复造

黑名双配备:

http {
......
登录后复造
登录后复造
geo $whiteiplist {
 default 1;
 1两7.0.0.1 0;
 10.10.0.0/二4 0;
}
map $whiteiplist $limit {
 1 $binary_remote_addr;
 0 "";
}
limit_conn_zone $limit zone=one:10m;
limit_req_zone $limit zone=fifa:10m rate=5r/s;
登录后复造
......
server {
......
limit_conn one 5;
limit_req zone=fifa burst=100;
......
}}
登录后复造
登录后复造

分析:

geo指令界说一个利剑名双$whiteiplist, 默许值为1, 一切皆蒙限定。 若是客户端ip取利剑名双列没的ip相婚配,则$whiteiplist值为0也等于没有蒙限止。

map指令是将$whiteiplist值为1的,也即是蒙限定的ip,映照为客户端ip。将$whiteiplist值为0的,也即是利剑名双ip,映照为空的字符串。

limit_conn_zone以及limit_req_zone指令对于于键为空值的将会被纰漏,从而完成对于于列进去的ip没有作限止。

以上即是Nginx若何经由过程geo模块装备黑名双的具体形式,更多请存眷萤水红IT仄台此外相闭文章!

点赞(25) 打赏

评论列表 共有 0 条评论

暂无评论

微信小程序

微信扫一扫体验

立即
投稿

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部