当前位置:首页 > 技术文章 > 正文内容

Nginx通过ip进行限流,并增加白名单

arlanguage3个月前 (01-22)技术文章23

通过IP进行限制

limit_req_zone $binary_remote_addr zone=iplimit:20m rate=10r/s ;

remote_addr,表示通过IP地址进行限流

iplimit,指定一块内存区域大小为20M,名字为iplimit,用于记录访问的频率信息

rate=10r/s,表示每秒放行一个请求,可以根据业务需求指定【标识访问的限流频率】,Nginx 实际上以毫秒为粒度来跟踪请求信息,因此 10r/s 实际上是限制:每100毫秒处理一个请求。这意味着,自上一个请求处理完后,若后续100毫秒内又有请求到达,将拒绝处理该请求

limit_req zone=iplimit burst=3 nodelay;

nodelay:设置了nodelay,就会对burst中的请求不在采用延迟处理,而是立即返回错误。

burst:默认值为0,就那个大碗,表示在超过设定的访问速率后能额外处理的请求数。


#达到最大上限值记录日志级别

语法:limit_req_log_lever info|notice|warn|error;

默认值:limit_req_log_level error;

生效范围:http,server,location


#达到最大上限值,向客户端返回特定的错误码

语法:limit_req_status code;

默认值:limit_req_status 503;

生效范围:http,server,location



限流白名单(根据不同的二级路径进行限流,并配置白名单)

#http段
#www limit
     geo $limit_www {
         default 1;
         1.1.1.0/24 0;
         1.1.1.1/32 0;
     }

     map $limit_www $limit_key_www {
         0 "";
         1 $binary_remote_addr;
     }
     limit_req_zone $limit_key_www zone=iplimit_www:20m rate=2r/s;

#openapi limit
     geo $limit_openapi {
         default 1;
         2.2.2.0/24 0;
         2.2.2.2/32 0;
     }
     map $limit_openapi $limit_key_openapi {
         0 "";
         1 $binary_remote_addr;
     }
     limit_req_zone $limit_key_www zone=iplimit_openapi:20m rate=200r/s;

#server段
     location /www/ {
         limit_req zone=iplimit_www burst=3 nodelay;
         limit_req_status 429;
         proxy_pass http://www/;
     }
     location /openapi/ {
         limit_req zone=iplimit_openapi burst=3 nodelay;
         limit_req_status 429;
         proxy_pass http://openapi/;
     }

geo 指令可以根据IP创建变量$limit。$limit的默认值是1,如果匹配到了下面的IP,则返回对应的值(这里返回的是0)。

之后通过 map 指令,将$limit的值映射为$limit_key:在白名单内的,$limit_key 为空字符串,不在白名单内的,则为$binary_remote_addr。当limit_req_zone指令的第一个参数是一个空字符串,限制不起作用,因此白名单的IP 地址(在1.1.1.1/32和1.1.1.0/23子网中)没有被限制,其它IP地址都被限制为2r/s。

扫描二维码推送至手机访问。

版权声明:本文由AR编程网发布,如需转载请注明出处。

本文链接:http://www.arlanguage.com/post/1029.html

标签: nginx ip段
分享给朋友:

“Nginx通过ip进行限流,并增加白名单” 的相关文章

分享一段PHP代码的加密扩展 分享一段php代码的加密扩展怎么弄

介绍一个简洁、高性能、跨平台的 PHP7 代码加密扩展特点简单快速,经实测,几乎不影响性能兼容 OPcache、Xdebug 等其他扩展支持 Linux、macOS、Windows 等系统兼容 Apache、Nginx + PHP-fpm、命令行等运行模式加密算法较简单,这是出于速度考虑,但仍不易解...

Windows下配置Nginx开机自启动

如何安装、配置网站就不说了,文章主要讲讲windows中如何让nginx开机自启动1.windows中配置nginx开机启动需要借助Windows Service Wrapper工具。可以通过地址http://repo.jenkins-ci.org/releases/com/sun/winsw/wi...

高端Linux 脚本很有用,赶紧学起来!

Linux 脚本?准确的说叫 Linux Shell 脚本,Shell 脚本是一种被设计用来运行命令行解释器,他是 Linux 系统的一大特色之一。命令行是 Linux 系统中一种非常重要的交互方式,而它的实现基于 Linux 内核和 Shell 程序,为用户提供了强大和灵活的操作方式。使用 Lin...

http请求域名强制跳转https

网站添加了https证书后,当http方式访问网站时就会报404错误,所以需要做http到https的强制跳转设置. ---------------一、采用nginx的rewrite方法--------------------- 下面是将所有的http请求通过rewrite重写到https上。 例如...

Nginx的安装及配置详解 nginx1.12安装

Nginx是一个强大的免费开源的HTTP服务器和反向代理服务器。在Web开发项目中,nginx常用作为静态文件服务器处理静态文件,并负责将动态请求转发至应用服务器(Django, Flask, etc)。熟悉Nginx的配置对Web开发和运维人员来说至关重要。本文整理了Nginx的配置大全,可以作为...

大数据分析工程师入门15-数据收集

数据与智能 本公众号关注大数据与人工智能技术。由一批具备多年实战经验的技术极客参与运营管理,持续输出大数据、数据分析、推荐系统、机器学习、人工智能等方向的原创文章,每周至少输出10篇精品原创。同时,我们会关注和分享大数据与人工智能行业动态。欢迎关注。 作者:凯凯连导语上一篇文章我们简单介绍了下大数...