在很多场景我们需要限制用户操作频次,这个限制包含对单个用户、整体用户、某一类用户、某一类用户的某一类行为,限流可以配合队列一起使用用以对整体进行限制,比如发验证码、提交、上传,也可以单独使用,比如对单个用户访问频次的限制... ...本文主要讲使用redis进行三种基本限流手段。
1.时间段限流
laravel路由限流中间件用的就是这种方法,根据用户访问接口、用户id等生成唯一key,并设置有效期限,在有效期限内,每接到一个访问就把key的value + 1,并返回在该有效期内还可以访问多少次,在有效期内value到达限制值即返回429错误,并返回多少秒后会重新计算和重新计算的时间点。
if(key 不存在 || key 过期){
setnx(key,1,limit);
}else{
if(get(key))< limit){
incr(key);
return "还可以写入limit-get(key)个数据";
}else{
return "超出限制,需要等待ttl(key) s";
}
}
/**
* Get the Lua script for acquiring a lock.
*
* KEYS[1] - The limiter name
* ARGV[1] - Current time in microseconds 当前时间:毫秒、浮点数
* ARGV[2] - Current time in seconds 当前时间:秒
* ARGV[3] - Duration of the bucket 限制时间
* ARG