最近因为双11要来临,公司须要在接口请求上,作一下并发限制的处理,或者作一个防止刷单的安全拦截:
好比:一个接口请求,限制每秒请求总数为200次,超过200次就等待,等下一秒,再次请求,这里用到一个redis做为一个计数器的模式来实现。php
INCR key
将 key 中储存的数字值增一。web
若是 key 不存在,那么 key 的值会先被初始化为 0 ,而后再执行 INCR 操做。redis
若是值包含错误的类型,或字符串类型的值不能表示为数字,那么返回一个错误。api
这是一个针对字符串的操做,由于 Redis 没有专用的整数类型,因此 key 内储存的字符串被解释为十进制 64 位有符号整数来执行 INCR 操做。
code:redis> SET test 20
安全
OK
redis> INCR test
(integer) 21
redis> GET test # 数字值在 Redis 中以字符串的形式保存
"21"
计数器是 Redis 的原子性自增操做可实现的最直观的模式了,它的想法至关简单:每当某个操做发生时,向 Redis 发送一个 INCR 命令。并发
好比在一个 web 应用程序中,若是想知道用户在一年中天天的点击量,那么只要将用户 ID 以及相关的日期信息做为键,并在每次用户点击页面时,执行一次自增操做便可。学习
好比用户名是 peter ,点击时间是 2012 年 3 月 22 日,那么执行命令 INCR peter::2012.3.22 。
$redisKey = “api_name_” + $api;
$count = $this->redis->incr($redisKey);
if ($count == 1) {
//设置有效期一s
$this->redis->expire($redisKey,1);//设置一s的过时时间
}
if (count > 200) {//防止刷单的安全拦截
return false;//超过就返回false
}
//后续处理this
这就简单的实现了redis计数器的应用,另外还有如下方法:code
如下几种方式扩展这个简单的模式:接口
能够经过组合使用 INCR 和 EXPIRE ,来达到只在规定的生存时间内进行计数(counting)的目的。
客户端能够经过使用 GETSET 命令原子性地获取计数器的当前值并将计数器清零,更多信息请参考 GETSET 命令。
使用其余自增/自减操做,好比 DECR 和 INCRBY ,用户能够经过执行不一样的操做增长或减小计数器的值,好比在游戏中的记分器就可能用到这些命令。