找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1022|回复: 0
打印 上一主题 下一主题

在Nginx下针对IP和目录限速

[复制链接]

2487

主题

2487

帖子

7391

积分

论坛元老

Rank: 8Rank: 8

积分
7391
跳转到指定楼层
楼主
发表于 2018-2-18 04:50:16 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

                  
[color=]在某种应用场景下,我们需要在Nginx下对IP和目录进行限速;本文通过Nginx的limit_zone和limit_rate等方式实现对IP和目录的限速。
   
    从Nginx配置与应用详解专题的投票结果来看,Nginx已经是目前仅次于APache和MS IIS的Web服务器。Nginx优秀的高并发支持和高效的负载均衡是我们选择它的理由。但有时我们希望它能做的更多。本文将向您介绍如何在Nginx下对IP和目录进行限速,在某种应用场景下,这也是个常见需求。
    Nginx可以通过HTTPLimitZoneModule和HTTPCoreModule两个目录来限速。
    示例:
[ol]

  • [color=]limit_zone one $binary_remote_addr 10m;  

  • [color=]

  • [color=]location / {   

  • [color=]        limit_conn one 1;   

  • [color=]        limit_rate 100k;   
  • }
        说明:
        limit_zone,是针对每个IP定义一个存储session状态的容器。这个示例中定义了一个10m的容器,按照32bytes/session,可以处理320000个session。
        然后针对目录进行设定。
    [color=]limit_conn one 1;
      
        是限制每个IP只能发起一个连接。
    [color=]limit_rate 100k;

        是对每个连接限速100k. 注意,这里是对连接限速,而不是对IP限速。如果一个IP允许两个并发连接,那么这个IP就是限速limit_rate x 2。
    [/ol]
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端