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

來源:互聯網
上載者:User

標籤:integer   queue   客戶   user   int   用法   隊列   其他   ESS   

Redis Watch 命令

作用:
用於監視一個(或多個) key ,如果在事務執行之前這個(或這些) key 被其他命令所改動,那麼事務將被打斷。
用法:

redis 127.0.0.1:6379> WATCH key1 key2OK
Redis Unwatch 命令

作用:
用於取消 WATCH 命令對所有 key 的監視。
用法:

redis 127.0.0.1:6379> UNWATCHOK
Redis Multi 命令

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

redis 127.0.0.1:6379> MULTI            # 標記事務開始OKredis 127.0.0.1:6379> INCR user_id     # 多條命令按順序入隊QUEUEDredis 127.0.0.1:6379> INCR user_idQUEUEDredis 127.0.0.1:6379> INCR user_idQUEUEDredis 127.0.0.1:6379> PINGQUEUEDredis 127.0.0.1:6379> EXEC             # 執行1) (integer) 12) (integer) 23) (integer) 34) PONG
利用watch實現incr
具體做法如下:      WATCH mykey      val = GET mykey      val = val + 1      MULTI      SET mykey $val      EXEC

在擷取mykey的值之前先通過WATCH命令監控了該鍵,此後又將set命令包圍在事務中,這樣就可以有效保證每個串連在執行EXEC之前,如果當前串連擷取的mykey的值被其它串連的用戶端修改,那麼當前串連的EXEC命令將執行失敗。這樣調用者在判斷傳回值後就可以獲悉val是否被重新設定成功。

注意點:
  • 由於WATCH命令的作用只是當被監控的索引值被修改後阻止之後一個事務的執行,而不能保證其他用戶端不修改這一索引值,所以在一般的情況下我們需要在EXEC執行失敗後重新執行整個函數。
  • 執行EXEC命令後會取消對所有鍵的監控,如果不想執行事務中的命令也可以使用UNWATCH命令來取消監控。
樣本:
開啟兩個redis-cli命令列視窗 session 1 和 session 2session 1:redis 127.0.0.1:6379> set test 1   # 設定test="1"OKredis 127.0.0.1:6379> get test     # 擷取到test的值為"1""1"redis 127.0.0.1:6379> watch test   # 監視testOKredis 127.0.0.1:6379> multi        # 開啟事務OKredis 127.0.0.1:6379> set test 2   # 將test設為"2"QUEUEDredis 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      # 取消監視所有keyOKredis 127.0.0.1:6379> set test 4   # 非事務變更test的值為"4"OKredis 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  # 監視testOKredis 127.0.0.1:6379> multi       # 開啟事務OKredis 127.0.0.1:6379> set test 3  # 將test設為"3"QUEUEDredis 127.0.0.1:6379> exec        # 執行事務1) OKredis 127.0.0.1:6379> get test    # 擷取到test="3""3"

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

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.