redis深度理解底层锁原理

redis锁

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

clipboard.png

相关文章
相关标签/搜索