Nginx怎么实现限流

技术Nginx怎么实现限流这篇文章主要为大家展示了“Nginx怎么实现限流”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Nginx怎么实现限流”这篇文章吧。Nginx 限流N

本文主要给大家展示“Nginx是如何实现限流的”,简单易懂,组织清晰,希望能帮你解开疑惑。让边肖带领你学习《Nginx如何实现限流》一文。

Nginx 限流

Nginx为我们提供了请求限制模块(ngx_http_limit_req_module)、基于令牌桶算法的流量限制模块(ngx_stream_limit_conn_module),可以方便的控制令牌速率,自定义调节限流,实现基本的限流控制…

00-1010请求限制的功能来自ngx_http_limit_req_module模块。要使用它,首先需要在http配置部分定义限制的参考标准和状态缓冲区大小。

limit_req_zone只能在http范围内配置;

$binary_remote_addr表示客户端请求的IP地址;

mylimit本身定义的变量名;

速率请求频率,每秒允许多少请求;

limit_req对应于limit_req_zone,突发指示缓存请求的数量,即任务队列。

以下配置被定义为使用客户端的IP作为参考,并使用10M大小的状态缓冲区。结束速率=1r/s意味着每个IP的请求每秒只被接受一次。

10M状态缓冲空间够吗?官方给出的答案是,1M缓存空间在32位系统中可以服务32000个IP地址,在64位系统中可以服务16000个IP地址,因此需要根据情况进行调整。如果状态缓存耗尽,所有后续请求都将收到503(服务暂时不可用)错误。

脚本代码

#定义请求频率为每秒1个请求(nr/s)的mylimit缓冲区(容器)

limit _ req _ zone $ binary _ remote _ addrzone=my limit :10m rate=1r/s;

服务器{

列表70;

位置/

#nodelay不会延迟处理

#burst是配置的超额处理,可以简单理解为排队机制。

#上面配置了同一IP每秒只能发送一个请求(1r/s),这里配置为缓存三个请求,这意味着同一秒内只能有四个任务成功响应,而其他任务请求失败(503服务不可用)。

limit _ reqzone=my limit burst=3 modelay;

proxy _ pass http://localhost :7070;

}

}测试代码

为了方便起见,这里提供了JAVA和AB测试代码。

#-n指定执行压力测试的总次数。

#-c是指定的并发数。

a B- n5-c 5http://192 . 168 . 0 . 133:70/indexpackagecom . battcn . limiting;

import org . spring framework . http . response entity;

import org . spring framework . web . client . rest template;

import Java . util . concurrent.completablefuture;

import Java . util . concurrent . executionexception;

import Java . util . concurrent . executorservice;

import Java . util . concurrent . executors;

/**

*@authorLevin

* @自2018年7月27日起

*/

public classinginxlimitertest {

public static void main(String[]args)nb

sp;throws ExecutionException, InterruptedException {
        ExecutorService service = Executors.newFixedThreadPool(5);
        for (int i = 0; i < 6; i++) {
            CompletableFuture.supplyAsync(() -> {
                final ResponseEntity<String> entity = new RestTemplate().getForEntity("http://192.168.0.133:70/index", String.class);
                return entity.getBody();
            }, service).thenAccept(System.out::println);
        }
        service.shutdown();
    }
}

测试日志

此处提供 AB 测试结果 JAVA 的日志就不贴了,5个请求其中一个请求是有问题的,出问题的那个就是被拒绝请求的…

[root@localhost myconf]# ab -n 5 -c 5 http://192.168.0.133:70/index
Document Path:          /index
Document Length:        34 bytes
Concurrency Level:      5
Time taken for tests:   0.002 seconds
Complete requests:      5
Failed requests:        1
   (Connect: 0, Receive: 0, Length: 1, Exceptions: 0)

并发限制

Nginx 并发限制的功能来自于 ngx_http_limit_conn_module 模块,跟请求配置一样,使用它之前,需要先定义参照标准和状态缓存区。

limit_conn_zone 只能配置在 http 范围内;

$binary_remote_addr 表示客户端请求的IP地址;

myconn 自己定义的变量名(缓冲区);

limit_rate 限制传输速度

limit_conn 与 limit_conn_zone 对应,限制网络连接数

下面的配置就是定义了使用客户端的 IP 作为参照依据,并使用一个 10M 大小的状态缓存区。限定了每个IP只允许建立一个请求连接,同时传输的速度最大为 1024KB

脚本代码

# 定义了一个 myconn 缓冲区(容器)
limit_conn_zone $binary_remote_addr zone=myconn:10m;
server {
listen  70;
location / {
# 每个 IP 只允许一个连接
limit_conn myconn 1;
# 限制传输速度(如果有N个并发连接,则是 N * limit_rate)
limit_rate 1024k;
proxy_pass http://localhost:7070;
}
}

以上是“Nginx怎么实现限流”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/115160.html

(0)

相关推荐

  • mysql修改表中的数据类型(mysql如何更改表的字段类型)

    技术mysql如何修改表的类型这篇文章主要介绍“mysql如何修改表的类型”,在日常操作中,相信很多人在mysql如何修改表的类型问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql如

    攻略 2021年12月13日
  • Oracle AWR如何实现数据导入/导出

    技术Oracle AWR如何实现数据导入/导出这篇文章主要介绍Oracle AWR如何实现数据导入/导出,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!LINUX状态下,连接oracle用户:su

    攻略 2021年11月11日
  • Tomcat9中容器结构与生命周期的示例分析

    技术Tomcat9中容器结构与生命周期的示例分析这篇文章将为大家详细讲解有关Tomcat9中容器结构与生命周期的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。容器的生命周期容器

    攻略 2021年12月11日
  • 三角形任意两边之和大于第三边,三角形的三边之间有怎样的关系

    技术三角形任意两边之和大于第三边,三角形的三边之间有怎样的关系1、三角形的三边关系:任意两边之和大于第三边三角形任意两边之和大于第三边,任意两边之差小于第三边。2、设三角形三边为a,b,c则a+b>c,a>c-b,b+c

    生活 2021年10月21日
  • hadoop的hive和spark有什么区别(spark和hive的优缺点)

    技术如何实现Apache Hive 和Spark的对比分析本篇文章给大家分享的是有关如何实现Apache Hive 和Spark的对比分析,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不

    攻略 2021年12月17日
  • RAC主机配置ssh互信的方法教程

    技术RAC主机配置ssh互信的方法教程本篇内容主要讲解“RAC主机配置ssh互信的方法教程”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“RAC主机配置ssh互信的方法教程”吧

    攻略 2021年10月22日