网站首页 > 技术教程 正文
通过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。
猜你喜欢
- 2024-10-10 通过nginx日志分析IP UV和PV量(nginx日志访问量前十的ip)
- 2024-10-10 Nginx 之 realip模块 使用详解(nginx rewrite模块)
- 2024-10-10 nginx+lua站点防止ip刷新数据处理
- 2024-10-10 生产环境用shell进行nginx日志访问IP和URL统计
- 2024-10-10 https网站(nginx服务器)如何禁止“直接通过IP地址访问”
- 2024-09-14 nginx允许IP访问不生效问题「原创」
- 2024-09-14 Linux 配置Nginx反向代理教程和说明
- 2024-09-14 EFK收集nginx日志并展示来源IP地图
- 2024-09-14 Nginx反向代理:通过外网访问内网数据库(mysql)
- 2024-09-14 详解nginx限制IP恶意调用短信接口处理方法
你 发表评论:
欢迎- 最近发表
-
- Linux新手必看:几种方法帮你查看CPU核心数量
- linux基础命令之lscpu命令(linux中ls命令的用法)
- Linux lscpu 命令使用详解(linux常用ls命令)
- 如何查询 Linux 中 CPU 的数量?这几个命令要知道!
- 在linux上怎么查看cpu信息(linux如何查看cpu信息)
- 查看 CPU 的命令和磁盘 IO 的命令
- 如何在CentOS7上改变网卡名(centos怎么改网卡名字)
- 网工必备Linux网络管理命令(网工必备linux网络管理命令是什么)
- Linux 网络命令知多少(linux 网络 命令)
- Linux通过命令行连接wifi的方式(linux命令行连接无线网)
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
本文暂时没有评论,来添加一个吧(●'◡'●)