PHP+Redis解决订单限流的实际问题
问题描述:
本期为第一期,所以只能自己出题了
如何用Redis给订单限流,如每M秒允许N个访问
解决方案:
* //每秒放行一个 * isAllow('my_allow'); * * //每秒放行3个 * isAllow('my_allow',1,3); * * //每3秒放行2个 * isAllow('my_allow',3,2); */ function isAllow(string $key, int $timeInterval=1, int $max=1):bool{ if($timeInterval<1){ throw new Exception('时间间隔必须大于0'); } if($max<1){ throw new Exception('最大放行数必须大于0'); } $redis=new Redis(); $redis->connect('192.168.31.187'); if(!$redis->isConnected()){ throw new Exception('Redis服务连接失败'); } //对时间戳取模,使得每$timeInterval秒取得同一个时间戳 $time=time(); $key.=':'.($time-($time%$timeInterval)); //自增并返回自增后的结果 $index=$redis->incr($key); //如果是第一个访问,设置键的过期时间 if($index===1){ $redis->expire($key,$timeInterval+1); } return $index<$max+1; }
代码解读:
-
对时间取模,使得键名每$timeInterval秒更新一次
-
incr()方法自增键的值,如果键不存在则先创建一个值为0的键再进行自增
-
根据自增原理,同键名下第N次自增返回的值就是N
-
键名每$timeInterval秒更新一次,所以在创建键的$timeInterval+1秒后键就不再有价值
以上,欢迎大家提问、纠错、补充、优化。
以上就是PHP+Redis解决订单限流的实际问题的详细内容,更多请关注毛票票其它相关文章!