Redis(十三):Redis实现乐观锁
生活随笔
收集整理的這篇文章主要介紹了
Redis(十三):Redis实现乐观锁
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1、悲觀鎖與樂觀鎖
樂觀鎖和悲觀鎖是一種程序設計思想,而不是具體的代碼。樂觀鎖和悲觀鎖應用的場景有很多,在數據庫和多線程等等都會用到。
- 悲觀鎖:總是假設最壞的情況,每次去拿數據的時候都認為別人會修改,所以每次在拿數據的時候都會上鎖,這樣別人想拿這個數據就會阻塞直到它拿到鎖(共享資源每次只給一個線程使用,其它線程阻塞,用完后再把資源轉讓給其它線程)。
- 樂觀鎖:總是假設最好的情況,每次去拿數據的時候都認為別人不會修改,所以不會上鎖,但是在更新的時候會判斷一下在此期間別人有沒有去更新這個數據。
2、Redis監視測試
正常情況,執行成功:
127.0.0.1:6379> set money 100 OK 127.0.0.1:6379> set out 0 OK 127.0.0.1:6379> watch money //監視money對象 OK 127.0.0.1:6379> multi //事務正常結束,事務期間,沒有發生變動,這個時候就正常執行成功 OK 127.0.0.1:6379> DECRBY money 20 QUEUED 127.0.0.1:6379> INCRBY out 20 QUEUED 127.0.0.1:6379> EXEC 1) (integer) 80 2) (integer) 20測試多線程修改只,使用watch當作Redis的樂觀鎖操作:
127.0.0.1:6379> watch money //監視money對象 OK 127.0.0.1:6379> multi OK 127.0.0.1:6379> DECRBY money 20 QUEUED 127.0.0.1:6379> INCRBY out 20 QUEUED 127.0.0.1:6379> EXEC //執行之前,另一個線程修改了我們的值,這時候就會導致執行失敗! (nil) 127.0.0.1:6379> unwatch money //先解鎖 OK 127.0.0.1:6379> watch money //再次放置鎖,再次見識money最新值 OK 127.0.0.1:6379> multi OK 127.0.0.1:6379> DECRBY money 20 QUEUED 127.0.0.1:6379> INCRBY out 20 QUEUED 127.0.0.1:6379> EXEC總結
以上是生活随笔為你收集整理的Redis(十三):Redis实现乐观锁的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JDK源码解析之 java.lang.C
- 下一篇: linux cmake编译源码,linu