W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
get key
如果key不存在返回nil
getset key value
原子的設(shè)置key的值,并返回key的舊值。如果key不存在返回nil。應(yīng)用場(chǎng)景:設(shè)置新值,返回舊值,配合setnx可實(shí)現(xiàn)分布式鎖。
分布式鎖的思路:注意該思路要保證多臺(tái)Client服務(wù)器的NTP一致。
偽代碼為:
# get lock
lock = 0
while lock != 1:
timestamp = current Unix time + lock timeout + 1
lock = SETNX lock.foo timestamp
if lock == 1 or (now() > (GET lock.foo) and now() > (GETSET lock.foo timestamp)):
break;
else:
sleep(10ms)
# do your job
do_job()
# release
if now() < GET lock.foo:
DEL lock.foo
以上是一個(gè)單Server 的分布式鎖思路,官網(wǎng)上還介紹了另一個(gè)單機(jī)使用超時(shí)方式進(jìn)行的思路,和這個(gè)基本一致,并且在同一個(gè)文檔中介紹了一個(gè)名為redlock的多Server容錯(cuò)型分布式鎖的算法,同時(shí)列出了多語(yǔ)言的實(shí)現(xiàn)。這個(gè)算法的優(yōu)勢(shì)在于幾個(gè)服務(wù)器可以有少量的時(shí)間差,不要求嚴(yán)格時(shí)間一致。
也可以設(shè)計(jì)一個(gè)按小時(shí)計(jì)算的計(jì)數(shù)器,可以用GetSet獲取計(jì)數(shù)并重置為0。
mget key1 key2 ... keyN
一次獲取多個(gè)key的值,如果對(duì)應(yīng)key不存在,則對(duì)應(yīng)返回nil
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: