nginx配置限制同一个ip的访问频率
nginx可以通过ngxhttplimitconnmodule和ngxhttplimitreqmodule配置来限制ip在同一时间段的访问次数.
ngxhttplimitconnmodule
该模块用于限制每个定义的密钥的连接数,特别是单个IP地址的连接数.使用limitconnzone和limit_conn指令.
1、在nginx.conf里的http{}里加上如下代码:
limit_conn_zone $binary_remote_addr zone=perip:10m;
limit_conn_zone $server_name zone=perserver:10m;
2、在需要限制并发数和下载带宽的网站配置server{}里加上如下代码:
limit_conn perip 2;
limit_conn perserver 20;
limit_rate 100k;
补充说明下参数:
$binaryremoteaddr是限制同一客户端ip地址; $servername是限制同一server最大并发数; limitconn为限制并发连接数; limit_rate为限制下载速度;
ngxhttplimitreqmodule
用于限制每一个定义的密钥的请求的处理速率,特别是从一个单一的IP地址的请求的处理速率。使用“泄漏桶”方法进行限制.指令:limitreqzone和limit_req.
1、在nginx.conf里的http{}里加上如下代码:
limit_req_zone $binary_remote_addr zone=perip:10m rate=1r/s;
limit_req_zone $server_name zone=perserver:10m rate=10r/s;
说明如下 定义一个名为one的limitreqzone用来存储session,大小是10M内存, 以$binaryremoteaddr 为key,限制平均每秒的请求为1个, 1M能存储16000个状态,rete的值必须为整数
2、在需要限制请求速度网站配置server{}里加上如下代码
limit_req zone=perip burst=5 nodelay; #漏桶数为5个.也就是队列数.nodelay:不启用延迟.
limit_req zone=perserver burst=10; #限制nginx的处理速率为每秒10个
限制每ip每秒不超过1个请求,漏桶数burst为5,也就是队列. nodelay,如果不设置该选项,严格使用平均速率限制请求数,超过的请求被延时处理. 举个栗子: 设置rate=20r/s每秒请求数为20个,漏桶数burst为5个, brust的意思就是,如果第1秒、2,3,4秒请求为19个,第5秒的请求为25个是被允许的,可以理解为20+5 但是如果你第1秒就25个请求,第2秒超过20的请求返回503错误. 如果区域存储空间不足,服务器将返回503(服务临时不可用)错误 速率在每秒请求中指定(r/s)。如果需要每秒少于一个请求的速率,则以每分钟的请求(r/m)指定。
文档信息
版权声明:可自由转载(请注明转载出处)-非商用-非衍生
发表时间:2021年4月14日 21:02