nginx ip限制访问控制

本文详细介绍了Nginx的两种限流方法:ngx_http_limit_req_module 和 ngx_http_limit_conn_module。前者通过定义limit_req_zone来限制每秒的请求次数,并支持突发请求处理;后者则用于限制每个IP或服务器的最大并发连接数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ngx_http_limit_req_module:限制某一段时间内同一ip访问数实例

http{
    ...
    #定义一个名为allips的limit_req_zone用来存储session,大小是10M内存,
    #以$binary_remote_addr 为key,限制平均每秒的请求为20个,
    #1M能存储16000个状态,rete的值必须为整数,
    #如果限制两秒钟一个请求,可以设置成30r/m

    limit_req_zone $binary_remote_addr zone=allips:10m rate=20r/s;
    ...
    server{
        ...
        location {
            ...
            
           
       #限制每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)指定。
       limit_req zone=allips burst=5 nodelay;
       ...
} ... } ...}


ngx_http_limit_conn_module:限制某一段时间内同一ip访问数实例


 http { 
    limit_conn_zone $binary_remote_addr zone=perip:10m; 
    limit_conn_zone $server_name zone=perserver:10m 

    ... 

    server { 

        ... 

        limit_conn perip 10;       #单个客户端ip与服务器的连接数.
        limit_conn perserver 100;  #限制与服务器的总连接数

        }
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值