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)

相关推荐

  • 家中养什么花好,室内适合养哪种带香味的植物

    技术家中养什么花好,室内适合养哪种带香味的植物阳台花园菜园为您解答家中养什么花好。室内适合栽种哪些有香味的植物?在家里养些花花草草,调节气氛,是一件非常有雅兴的事。如果养护的花卉长势旺盛,开花繁多而又自带香气,可以为家里

    生活 2021年10月21日
  • 阿里巴巴开源Sentinel限流方案搭建是怎样的

    技术阿里巴巴开源Sentinel限流方案搭建是怎样的阿里巴巴开源Sentinel限流方案搭建是怎样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所

    攻略 2021年10月20日
  • SpringMVC实现原理解析

    技术SpringMVC实现原理解析 SpringMVC实现原理解析一、SpringMVC简介
    SpringMVC是一种基于Spring实现了Web MVC设计模式的请求驱动类型的轻量级Web框架,使用了

    礼包 2021年11月29日
  • 引擎ECS框架中system的语法糖是怎么实现的

    技术引擎ECS框架中system的语法糖是怎么实现的引擎ECS框架中system的语法糖是怎么实现的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。集(B

    攻略 2021年11月24日
  • 如何理解MYSQL中的SHOW VARIABLES语句

    技术如何理解MYSQL中的SHOW VARIABLES语句这篇文章将为大家详细讲解有关如何理解MYSQL中的SHOW VARIABLES语句,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知

    攻略 2021年11月23日
  • spring cloud gateway支持contextPath分析

    技术spring cloud gateway支持contextPath分析本篇内容主要讲解“spring cloud gateway支持contextPath分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实

    攻略 2021年11月17日