nginx 速率限制

1.限制并发数,限制所有客户端IP的访问数量,防止DDOS攻击:
       http{
               limit_conn_zone $binary_remote_addr  zone=perip:1m;
              
          }
 
    #$binary_remote_addr为客户端IP,以此为key存储;
    #建立一个 名为perip 1M空间的并发池  , 名称可以自定义

    server{
            location / {
                   limit_conn perip  2;
             }
     }
    #限制客户端IP的并发量是2,   perip为并发池名称, 名称要同http中定义的并发池相同


2.限制速率,限制客户端IP的请求速率
http{
              limit_req_zone  $binary_remote_addr zone=per_req:1m rate=10r/s;
              
          }
    #$binary_remote_addr为客户端IP,以此为key存储;每个IP  请求次数限制 10次/秒
    #建立一个 名为per_req1M空间的限速池  , 名称可以自定义
  server{
            location / {
                   limit_req  zone=per_req burst=5 nodelay;
             }
     }
    #限速池名称为:per_req  名称要同http定义的相同
    #最大延迟请求数量不大于5,超过5个会直接返回503错误;  
     #若添加了nodelay,一旦有延迟立即返回503,不用等。

3.限制并发数,限制域名、同一个url并发池

 http{
     
        limit_conn_zone $server_name  zone=perserver:1m;   #域名并发池
        limit_conn_zone $host$uri zone=peruri:1m;                 #相同URL线程池
}
  

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dadashitou

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值