百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

长这么大才读懂高并发核心编程,限流原理与实战,Nginx漏桶限流

off999 2025-01-05 19:31 26 浏览 0 评论

Nginx漏桶限流详解

使用Nginx可通过配置的方式完成接入层的限流,其ngx_http_limit_req_module模块所提供的limit_req_zone和limit_req两个指令使用漏桶算法进行限流。其中,limit_req_zone指令用于定义一个限流的具体规则(或者计数内存区),limit_req指令应用前者定义的规则完成限流动作。

假定要配置Nginx虚拟主机的限流规则为单IP限制为每秒1次请求,整个应用限制为每秒10次请求,具体的配置如下:

 #第一条规则名称为perip,每个相同客户端IP的请求限速在6次/分钟(1次/10秒)
limit_req_zone $binary_remote_addr zone=perip:10m rate=6r/m;
#第二条限流规则名称为preserver,同一虚拟主机的请求限速在10次/秒
 limit_req_zone $server_name zone=perserver:1m rate=10r/s;
 server {
 listen 8081 ;
 server_name localhost;
 default_type 'text/html';
 charset utf-8;
 limit_req zone=perip;
 limit_req zone=perserver;
 location /nginx/ratelimit/demo {
 echo "-uri= $uri -remote_addr= $remote_addr"
 "-server_name= $server_name" ;
 }
 }

上面的配置通过limit_req_zone指令定义了两条限流规则:第一条规则名称为perip,将来自每个相同客户端IP的请求限速在6次/分钟(1次/10秒);第二条限流规则名称为preserver,用于将同一虚拟主机的请求限速在10次/秒。

以上配置位于练习工程LuaDemoProject的src/conf/nginxratelimit.conf文件中,在使之生效前需要在openresty-start.sh脚本中换上该配置文件,然后重启Nginx。接下来开始验证上面的限流配置。在浏览器中输入如下测试地址:

http://nginx.server:8081/nginx/ratelimit/demo

10秒内连续刷新,第1次的输出如图9-9所示。

10秒内连续刷新,第1次之后的输出如图9-10所示。

接下来详细介绍Nginx的limit_req_zone和limit_req两个指令。

limit_req_zone用于定义一个限流的具体规则,limit_req应用前者所定义的规则。limit_req_zone指令的格式如下:

语法:limit_req_zone key zone=name:size rate=rate [sync];
上下文:http配置块limit_req_zone指令的key部分是一个表达式,其运行时的值将作

为流量计数的关键字,key表达式包含变量、文本和它们的组合。在上面的配置实例中,$binary_remote_addr、$server_name为两个Nginx变量,$binary_remote_addr为客户端IP地址的二进制值,$server_name为虚拟机主机名称。在限流规则应用之后,它们的值将作为限流关键字key值,同一个key值会在限流的共享内存区域保存一份请求计数,而limit_req_zone限流指令所配置的速度限制只会对同一个key值发生作用。

limit_req_zone指令的zone属性用于定义存储相同key值的请求计数的共享内存区域,格式为name:size,name表示共享内存区域的名称(或者说限流规则的名称),size为共享内存区域的大小。上面的配置实例中,perip:10m表示一个名字为perip、大小为10MB的内存区域。

1MB大约能存储16 000个IP地址,10MB大约可以存储16万个IP地址,也就是可以对16万个客户端进行并发限速,当共享内存区域耗尽时,Nginx会使用LRU算法淘汰最长时间未使用的key值。

limit_req_zone指令的rate属性用于设置最大访问速率,rate=10r/s表示一个key值每秒最多能计数的访问数为10个(10个请求/秒),rate=6r/m表示一个key值每分钟最多能计数的访问数为6个(1个请求/10秒)。由于Nginx的漏桶限流的时间计算是基于毫秒的,当设置的速度为6r/m时,转换一下就是10秒内单个IP只允许通过1个请求,从第11秒开始才允许通过第二个请求。

limit_req_zone指令只是定义限流的规则和共享内存区域,规则要生效的话,还得靠limit_req限流指令完成。

limit_req指令的格式如下:

语法:limit_req zone=name [burst=number] [nodelay | delay=number];

上下文:http配置块,server配置块,location配置块limit_req指令的zone区域属性指定的限流共享内存区域(或者说限流的规则)与限流规则指令limit_req_zone中的name对应。

limit_req指令的burst突发属性表示可以处理的突发请求数。

limit_req指令的第二个参数burst是爆发数量的意思,此参数设置一个大小为number的爆发缓冲区,当有大量请求过来时,超过了限流频率的请求可以先放到爆发缓冲区内,直到爆发缓冲区满后才拒绝。

limit_req指令的burst参数的配置使得Nginx限流具备一定的突发流量的缓冲能力(有点像令牌桶)。但是burst的作用仅仅是让爆发的请求先放到队列里,然后慢慢处理,其处理的速度是由limit_req_zone规则指令配置的速度(比如1个请求/10秒),在速率低的情况下,其缓冲效果其实并不太理想。如果想迅速处理爆发的请求,那么可以再加上nodelay参数,队列中的请求会立即处理,而不再按照rate设置的速度(平均间隔)慢慢处理。

本文给大家讲解的内容是高并发核心编程,限流原理与实战,Nginx漏桶限流详解

  1. 下篇文章给大家讲解的是高并发核心编程,限流原理与实战,实战:分布式令牌桶限流;
  2. 觉得文章不错的朋友可以转发此文关注小编;
  3. 感谢大家的支持!

相关推荐

win10系统如何还原系统(win10还原系统方法)

要想恢复到Win10原版系统,可以通过两种方式。一种是使用Win10系统恢复工具,该工具可以在Win10设置中找到,然后选择恢复选项,并按照步骤完成恢复操作即可。另一种方式是直接从Microsoft官...

老毛桃xp u盘启动(老毛桃xp u盘启动)

老毛桃安装纯净版XP的方法需要用到的工具:winxp纯净版系统iso镜像+启动U盘1、进入老毛桃,选第一个PE后找到我们事先准备好的纯净版系统iso镜像,右键点击加载虚拟磁盘(也可以利用虚拟光驱来加载...

无线wifi密码破解工具

WiFi万能密码WiFi万能密码可免费连接WiFi,极速发现无线WiFi信号,一键即可连接上网,同时还能检测WiFi的信号轻度及安全度,让你想怎么玩就怎么玩,不必在担心流量的问题。这款软件操作简单,一...

超级系统掠夺诸天(超级系统掠夺诸天万界)

杀了铁掌水上漂裘千仞就能获得他一身能为的是《史上最牛轮回》,作者:那一抹绯红。(这本书个人评价为“差”)

autocad软件免费下载(cad软件下载2021)

首先在浏览器上搜索cad,打开一个下载cad的地址,然后点击一个下载地址入口,然后下载成功,点击打开按钮。然后点击快速安装按钮,最后CAD完全下载完成,点击打开文件即可。CAD(ComputerAi...

ios下载网站(显卡bios下载网站)

ios网页下的app安装方法如下首先下载完软件以后,打开设置,然后点击通用,选择设备管理,接着点击下载的软件,最后选择信任,点击信任即可。1.搜索文件:苹果自带浏览器下载内容会自动存储在文件中,打开手...

如何修复ie11浏览器(xbox无法连接无线网络)

可以通过清理缓存和数据来修复IE浏览器因为IE浏览器可能会受到缓存和数据的干扰,导致无法正常访问网页或者打开网页很慢。清理浏览器的缓存和数据可以解决这个问题,具体方法是:打开IE浏览器,点击“工具”-...

鼠标灵敏度(鼠标灵敏度转换器)

具体算法游戏内灵敏度×DPI=eDPIDPI是鼠标的定位精度,可理解为鼠标本身的灵敏度。而eDPI是最终灵敏度举例:同一特定游戏中,游戏内灵敏度10×800dpi=游戏内灵敏度5×1600dpi...

阿里云盘网页版登录(阿里云盘网页版登录入口)
  • 阿里云盘网页版登录(阿里云盘网页版登录入口)
  • 阿里云盘网页版登录(阿里云盘网页版登录入口)
  • 阿里云盘网页版登录(阿里云盘网页版登录入口)
  • 阿里云盘网页版登录(阿里云盘网页版登录入口)
tplogincn官网手机登录页面(tplogin 官网登录)

旧版本的TP-Link路由器的登陆网址是:192.168.1.1;新版本的TP-Link路由器的登陆网址是:tplogin.cn;TP-Link迷你路由器的登陆网址是:192.168.1.253。接下...

电脑黑屏怎么修(电脑黑屏怎么修复没有鼠标箭头)

电脑主机故障引起的黑屏故障主要可以分为以下几类:1.主机电源引起的故障主机电源损坏或主机电源质量不佳引起的黑屏故障很常见。例如,当你添加了一些新设备之后,显示器便出现了黑屏故障,排除了配件质量及兼容性...

电脑打不开的原因(电脑打不开的原因怎么解决)

这是关机时出现死机了,如果不经常出现,直接按关机按钮关机就是了。如果经常发生,可以测试一下cpu的温度是否过高,如果高清一下灰,其它就是重新插拔一下内存清一下灰。系统方面,关机前将所有的程序关闭在关机...

免费注册邮箱163官网(邮箱注册163免费注册下载)

输入www.163.com找到163免费邮入口注册就可以了。官网是https://www.163.net和https://163vip.com。在这里我们就可以随意打开一个浏览器,输入官网网址注册登录...

电脑开机不启动(电脑开机不启动程序怎么设置)

1、电脑启动时连续按下F8进入安全模式,然后关机,再次正常启动电脑试试。2、使用WinPE启动,运行CMD(命令行模式),在C:\windows\system32目录下,运行如下三个命令bcdedi...

电脑文件夹设置密码的软件(电脑文件夹设置打开密码)

是的,一些操作系统允许用户设置密码保护文件夹或文件以增加安全性。例如,在Windows操作系统中,可以使用BitLocker或EFS对整个驱动器或单个文件夹进行加密,并设置访问密码。在MacOS中,...

取消回复欢迎 发表评论: