系统运维

nginx配置限制同一个ip的访问频率

  • nginx 可以通过两个维度来限制并发请求:

一个是通过限制同一个IP每秒的请求次数,另一个是限制同一个server 每秒接受请求的次数

nginx可以通过ngx_http_limit_conn_modulengx_http_limit_req_module配置来限制ip在同一时间段的访问次数. 这两个模块在NGINX是默认编译进去的。

ngx_http_limit_req_module:用于限制每一个定义的密钥的请求的处理速率,特别是从一个单一的IP地址的请求的处理速率。使用“泄漏桶”方法进行限制.指令:limit_req_zonelimit_req

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;

补充说明下参数:

$binary_remote_addr是限制同一客户端ip地址;
$server_name是限制同一server最大并发数;
limit_conn为限制并发连接数;
limit_rate为限制下载速度;
    http {
      limit_req_zone $binary_remote_addr zone=perip:10m rate=50r/s; #50 requests per second
      limit_req_zone $server_name zone=perserver:10m rate=100r/s; #100 requests per second
      ...
      server {
        ...
          limit_req zone=perip burst=5 nodelay;  #漏桶数为5个.也就是队列数.nodelay:不启用延迟.
          limit_req zone=perserver burst=10;    #限制nginx的处理速率为每秒10个
        }

注意:http 块中设置完limit_req_zone 后并不能作用于server中,需要在sever块中 的location 中进行引用。

    http {
      limit_req_zone $binary_remote_addr zone=perip:10m rate=1r/s;
      ...
      #定义一个名为one的limit_req_zone用来存储session,大小是10M内存,  
      #以$binary_remote_addr 为key,限制平均每秒的请求为1个,
      #1M能存储16000个状态,rete的值必须为整数,
      server {
        ...
        location /search/ {
          limit_req zone=perip burst=5;
      #限制每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)指定。 
        }
  • 验证

设置POSTMAN

pm.test("test", function() {
    pm.response.to.have.status('OK');
    pm.response.to.be.ok;
})

file

经验证IP限频和server限频 可以同时设置

 location / {
        ...
        limit_req zone=perserver;
        limit_req zone=perip;
        ...
}

留言

您的电子邮箱地址不会被公开。 必填项已用*标注

闽ICP备20008591号-1