用户访问频率控制的redis模拟实现

用户访问频率控制的redis模拟实现

---》场景
限制用户 1分钟内登录不超过10次

---》模拟实现1
* 原理: 利用 key的存活时间内进行判断用户登录次数。
* 模拟实现
127.0.0.1:6379> clear
127.0.0.1:6379> set user1 1
OK
127.0.0.1:6379> expire user1 60
(integer) 1
127.0.0.1:6379> set user1 2
OK
127.0.0.1:6379> get user1
"2"
127.0.0.1:6379> set user2 1
OK
127.0.0.1:6379> expire user2 60
(integer) 1
127.0.0.1:6379> set user1 3
OK
127.0.0.1:6379> ttl user1
(integer) -1
127.0.0.1:6379> exists user2
(integer) 0
127.0.0.1:6379> get user2
(nil)
127.0.0.1:6379>

* 改进:创建key 和 设置存活时间放到一个事务里面
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set user3 1
QUEUED
127.0.0.1:6379> expire user3 60
QUEUED
127.0.0.1:6379> exec
1) OK
2) (integer) 1
127.0.0.1:6379> ttl user3
(integer) 51
127.0.0.1:6379> get user3
"1"
127.0.0.1:6379>

---》模拟实现2
* 原理:一个链表存10个登录时间,通过对比时间分析此用户登录频率
* 模拟实现
127.0.0.1:6379> lpush userlogintime "time1"
(integer) 1
127.0.0.1:6379> llen userlogintime
(integer) 1
127.0.0.1:6379> lpush userlogintime "time2"
(integer) 2
127.0.0.1:6379> llen userlogintime
(integer) 2
127.0.0.1:6379> lindex userlogintime 0
"time2"
127.0.0.1:6379> lindex userlogintime 1
"time1"
127.0.0.1:6379>

猜你喜欢

转载自ynp.iteye.com/blog/2238652