分布式限流(二)之 Nginx 限流

本文探讨了在流量层限流方面,Nginx 如何通过 IP 限流和连接数限流来控制访问。IP 限流利用令牌桶算法限制同一 IP 单位时间内的访问次数,而连接数限流则提供了另一种限制手段。同时提到在接口层限流时,可以结合 Nginx+Lua 脚本来实现,确保原子性并利用共享字典进行计数。文中还讨论了在高并发场景下如何选择限流策略,如分片、降级或使用 Redis+Lua 等方案。
摘要由CSDN通过智能技术生成

流量层限流:

Nginx之 IP 限流(限制同一ip单位时间访问数)

# $binary_remote_addr  关键字 表示通过remote_addr这个标识来做限制,“binary_”的目的是缩写内存占用量,是限制同一客户端ip地址
# zone=iplimit:20m 名叫iplimit的内存区域,大小为20兆 (用来记录访问频率信息)
# rate=1r/s 每秒放行一个请求 rate=100r/m 每分钟放行100个 
limit_req_zone $binary_remote_addr zone=iplimit:20m rate=1r/s;

# 服务级别限制
limit_req_zone $server_name zone=serverlimit:10m rate=10r/s;

server {
   
	server_name www.test.com;
	location /app {
   
		proxy_pass	http://127.0.0.1:8080;
		# 基于IP地址限制
		# zone=iplimit 引用 limit_req_zone 
		# burst=2 设置大小为2的缓冲区 假设当前突然涌入三个请求 丢弃一个
		# nodelay 缓冲区满了直接返回503异常 如果没有设置,则所有请求会依次等待排队
		limit_req zone=iplimit burst=2 nodelay;
		limit_req zone=serverlimit burst=1 nodelay;
	}
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值