Redis Watch 命令 作用: 用於監視一個(或多個) key ,如果在事務執行之前這個(或這些) key 被其他命令所改動,那麼事務將被打斷。 用法: Redis Unwatch 命令 作用: 用於取消 WATCH 命令對所有 key 的監視。 用法: Redis Multi 命令 作用: ...
Redis Watch 命令
作用:
用於監視一個(或多個) key ,如果在事務執行之前這個(或這些) key 被其他命令所改動,那麼事務將被打斷。
用法:
redis 127.0.0.1:6379> WATCH key1 key2
OK
Redis Unwatch 命令
作用:
用於取消 WATCH 命令對所有 key 的監視。
用法:
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是否被重新設置成功。
註意點:
- 由於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"