第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

關于redis分布式鎖的問題. 如果沒搶到鎖,那么應該怎么做,一直重復搶鎖的操作嗎?

關于redis分布式鎖的問題. 如果沒搶到鎖,那么應該怎么做,一直重復搶鎖的操作嗎?

慕妹3242003 2019-05-07 10:11:45
新手初學redis,嘗試redis鎖的時候,go代碼如下:funcmain(){client:=redis.NewClient(&redis.Options{Addr:"localhost:6379",})fori:=0;i
查看完整描述

2 回答

?
三國紛爭

TA貢獻1804條經驗 獲得超7個贊

看你要實現(xiàn)什么樣的鎖,或者基于什么樣的使用場景,比如說排它鎖,redis就實現(xiàn)不了,排它鎖在獲取不到鎖的情況下會阻塞進入等待隊列。在其他進程釋放鎖時會通知該進程再去獲取鎖,redis不提供這種基于key的通知機制,所以他實現(xiàn)不了排它鎖。不過分布式排它鎖,可以由Zookeeper實現(xiàn)。
另外一種分布式鎖的實現(xiàn)方式是通過樂觀鎖和自旋的實現(xiàn)方式,就是你說的那種方式,不過一般會設置超時時間,也就是redis設置key的ttl。這樣不至于進程一直等待下去。這種鎖適應于鎖內操作時間比較短,鎖競爭不是那么激烈的情況。
你說的那種100個進程搶鎖的情況,競爭這么激烈,還是用排它鎖比較好。
                            
查看完整回答
反對 回復 2019-05-07
?
泛舟湖上清波郎朗

TA貢獻1818條經驗 獲得超3個贊

這個原因充分說明了要項目驅動學習。只有你知道具體的項目的場景,才可以決定自己這個鎖怎么處理。比如,你如果搶不到資源就必須等待,而且是同步請求,那么必須等待。比如,你如果可以接受若一致,就可以考慮等待多久鎖,然后放棄,記錄日志或者其他補償機制。當然這個就類似于ReentrantLock里面的tryLock和tryLock(longtimeout,TimeUnitunit)的區(qū)別
                            
查看完整回答
反對 回復 2019-05-07
  • 2 回答
  • 0 關注
  • 543 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號