redis深度理解底層鎖原理

redis鎖

redis的鎖分別有INCR、SETNX、SET,那麼我們就開始來談談他們的用法和場景吧!

1.INCR:(計時器,+1操作)
    a) 語法:INCR key
    b) 場景:
        1)控制api 1秒內的多次訪問 ;
        2)記錄用戶每天訪問網站的登錄次數 ;

    c) 爲何我們說這個怎麼能算鎖呢,當然,單獨它肯定是算不了鎖的,因爲它本身就不斷的+1 +1,那我們怎麼辦呢,來看下面的:
        1) 我們如何實現場景1) 呢?

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的底層原理理解。

有疑問可以微聊我,或者添加公衆號瞭解,即將在公衆號深度剖析redis的事務鎖 + 分佈式鎖

clipboard.png

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章