redis的锁分别有INCR、SETNX、SET,那么咱们就开始来谈谈他们的用法和场景吧!php
1.INCR:(计时器,+1操做)
a) 语法:INCR key
b) 场景:
1)控制api 1秒内的屡次访问 ;
2)记录用户天天访问网站的登陆次数 ;redis
c) 为什么咱们说这个怎么能算锁呢,固然,单独它确定是算不了锁的,由于它自己就不断的+1 +1,那咱们怎么办呢,来看下面的:
1) 咱们如何实现场景1) 呢?api
FUNCTION LIMIT_API_CALL(ip) ts = CURRENT_UNIX_TIME() keyname = ip+":"+ts current = GET(keyname) IF current != NULL AND current > 10 THEN ERROR "too many requests per second" ELSE MULTI INCR(keyname,1) EXPIRE(keyname,1) EXEC PERFORM_API_CALL() END
2) 咱们如何实现场景2) 呢?缓存
INCR key
而后咱们在使用INCR的时候,通常都是要借助EXPIRE这个命令来结合使用:(我始终以为这种使用的场景太局限了,也就一秒,并且也只能+1,在增 1 就会不行,实际上咱们也就控制数量为 1 而已了,保证只能为 1)微信
$redis->incr($key); $redis->expire($key, $outtime); //设置生成时间为1秒
2.SETNX: 这个我就不讲了,由于在redis 2.6.12版本就会被抛弃的了分布式
3.SET:
a) 语法:SET KEY VALUE [EX seconds] [PX milliseconds] [NX|XX]
b) 场景:
1) set最大能够接受512M的长度,因此缓存放这里也是没问题哒;
2) 来对数据进行添加,好比要添加某个用户,若是存在,则不给予操做。
c) 其实这个锁的实现也就是利用了set的NX ,由于NX是若是存在,则不进行添加或修改,而后同时SET也是有expires的过时时间来释放锁的。网站
总结:
上面的这些所谓锁,也就是利用了expire,还有自带的NX来进行操做的必定保证,也就间接的实现锁的操做,这也是基于对redis的底层原理理解。spa
关注回复 wxq ,验证后即加入php微信群,即将在公众号深度剖析redis的事务锁 + 分布式锁code