W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
get key
如果key不存在返回nil
getset key value
原子的設(shè)置key的值,并返回key的舊值。如果key不存在返回nil。應(yīng)用場景:設(shè)置新值,返回舊值,配合setnx可實現(xiàn)分布式鎖。
分布式鎖的思路:注意該思路要保證多臺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
以上是一個單Server 的分布式鎖思路,官網(wǎng)上還介紹了另一個單機使用超時方式進行的思路,和這個基本一致,并且在同一個文檔中介紹了一個名為redlock的多Server容錯型分布式鎖的算法,同時列出了多語言的實現(xiàn)。這個算法的優(yōu)勢在于幾個服務(wù)器可以有少量的時間差,不要求嚴格時間一致。
也可以設(shè)計一個按小時計算的計數(shù)器,可以用GetSet獲取計數(shù)并重置為0。
mget key1 key2 ... keyN
一次獲取多個key的值,如果對應(yīng)key不存在,則對應(yīng)返回nil
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: