Redis事務涉及的watch、multi等命令

Redis Watch 命令

做用:
用於監視一個(或多個) key ,若是在事務執行以前這個(或這些) key 被其餘命令所改動,那麼事務將被打斷。
用法:redis

redis 127.0.0.1:6379> WATCH key1 key2
OK

Redis Unwatch 命令

做用:
用於取消 WATCH 命令對全部 key 的監視。
用法:session

redis 127.0.0.1:6379> UNWATCH
OK

Redis Multi 命令

做用:
用於標記一個事務塊的開始。事務塊內的多條命令會按照前後順序被放進一個隊列當中,最後由 EXEC 命令原子性(atomic)地執行。
用法:函數

redis 127.0.0.1:6379> MULTI            # 標記事務開始
OK
redis 127.0.0.1:6379> INCR user_id     # 多條命令按順序入隊
QUEUED
redis 127.0.0.1:6379> INCR user_id
QUEUED
redis 127.0.0.1:6379> INCR user_id
QUEUED
redis 127.0.0.1:6379> PING
QUEUED
redis 127.0.0.1:6379> EXEC             # 執行
1) (integer) 1
2) (integer) 2
3) (integer) 3
4) PONG

利用watch實現incr

具體作法以下:
      WATCH mykey
      val = GET mykey
      val = val + 1
      MULTI
      SET mykey $val
      EXEC

在獲取mykey的值以前先經過WATCH命令監控了該鍵,此後又將set命令包圍在事務中,這樣就能夠有效的保證每一個鏈接在執行EXEC以前,若是當前鏈接獲取的mykey的值被其它鏈接的客戶端修改,那麼當前鏈接的EXEC命令將執行失敗。這樣調用者在判斷返回值後就能夠獲悉val是否被從新設置成功。atom

注意點:

  • 因爲WATCH命令的做用只是當被監控的鍵值被修改後阻止以後一個事務的執行,而不能保證其餘客戶端不修改這一鍵值,因此在通常的狀況下咱們須要在EXEC執行失敗後從新執行整個函數。
  • 執行EXEC命令後會取消對全部鍵的監控,若是不想執行事務中的命令也可使用UNWATCH命令來取消監控。

示例:

打開兩個redis-cli命令行窗口 session 1 和 session 2
session 1:
redis 127.0.0.1:6379> set test 1   # 設置test="1"
OK
redis 127.0.0.1:6379> get test     # 獲取到test的值爲"1"
"1"
redis 127.0.0.1:6379> watch test   # 監視test
OK
redis 127.0.0.1:6379> multi        # 開啓事務
OK
redis 127.0.0.1:6379> set test 2   # 將test設爲"2"
QUEUED
redis 127.0.0.1:6379> exec         # 待 session 2 執行完畢後再執行 session 1 的exec命令,發現執行失敗
(nil)
redis 127.0.0.1:6379> get test     # 獲取test的值,發現test值爲 session 2 中所設置的"3"
"3"
redis 127.0.0.1:6379> unwatch      # 取消監視全部key
OK
redis 127.0.0.1:6379> set test 4   # 非事務變動test的值爲"4"
OK
redis 127.0.0.1:6379> get test     # 獲取到test="4"
"4"

session 2: 
redis 127.0.0.1:6379> get test    # 獲取到了 session 1 建立的test="1"
"1"
redis 127.0.0.1:6379> watch test  # 監視test
OK
redis 127.0.0.1:6379> multi       # 開啓事務
OK
redis 127.0.0.1:6379> set test 3  # 將test設爲"3"
QUEUED
redis 127.0.0.1:6379> exec        # 執行事務
1) OK
redis 127.0.0.1:6379> get test    # 獲取到test="3"
"3"
相關文章
相關標籤/搜索