特点:请求以恒定速率流入,往桶内以恒定速率往桶里注入令牌,每个请求进来时会获取令牌,若没有获取到令牌则会放弃此请求,当桶满后不再注入令牌。
特点:以恒定速率流出。当请求进来时放入桶内,遵循先进先出的规则,以设定的速率恒定流出,当桶放满时,不再接收请求。
nginx使用漏桶算法实现限流,当同一ip(一般使用ip限流,$binary_remote_addr)进入网关时,放入桶内,以恒定速率流出,若设定速率 rate=20r/s;则以0.05s一个的速率流出。
contentRateLimit:设定空间大小,用于储存桶请求,1M能存储16000 IP地址的访问信息。
配置:
# 漏桶限流
limit_req_zone $binary_remote_addr zone=contentRateLimit:10m rate=15r/s;
#使用限流配置
limit_req zone=contentRateLimit burst=5 nodelay;
burst:桶大小,一般配合nodelay一起用,
nodelay:不延时,立即处理
两者一起用用于处理突发流量,如上图配置当30个请求进入时,前20个直接放行,后面5个放入桶内并标记,因为配置了不延时,所以这5个请求会立刻处理。桶内标记以0.05s一个的速率从桶内移除,若有新的请求在设定速率之上,且桶内没有多余位置的请求则会放弃请求。所以剩余5个请求则放弃,由nginx返回503。
使用jmeter测试,15线程,1s,轮询2次。共计30次请求,其中nginx返回503请求5次,如上图搜索标记