本配备:
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仄台此外相闭文章!
发表评论 取消回复