做用:
用於監視一個(或多個) key ,若是在事務執行以前這個(或這些) key 被其餘命令所改動,那麼事務將被打斷。
用法:redis
redis 127.0.0.1:6379> WATCH key1 key2 OK
做用:
用於取消 WATCH 命令對全部 key 的監視。
用法:session
redis 127.0.0.1:6379> UNWATCH OK
做用:
用於標記一個事務塊的開始。事務塊內的多條命令會按照前後順序被放進一個隊列當中,最後由 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 mykey val = GET mykey val = val + 1 MULTI SET mykey $val EXEC
在獲取mykey的值以前先經過WATCH命令監控了該鍵,此後又將set命令包圍在事務中,這樣就能夠有效的保證每一個鏈接在執行EXEC以前,若是當前鏈接獲取的mykey的值被其它鏈接的客戶端修改,那麼當前鏈接的EXEC命令將執行失敗。這樣調用者在判斷返回值後就能夠獲悉val是否被從新設置成功。atom
打開兩個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"