Redis事務涉及的watch multi等命令

2022-03-18 18:50:33 字數 2210 閱讀 3790

作用:

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

用法:

redis 127.0.0.1:6379> watch key1 key2

ok

作用:

用於取消 watch 命令對所有 key 的監視。

用法:

redis 127.0.0.1:6379> unwatch

ok

作用:

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

用法:

redis 127.0.0.1:6379> multi            # 標記事務開始

okredis 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是否被重新設定成功。

開啟兩個redis-cli命令列視窗 session 1 和 session 2

session 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 # 監視test

okredis 127.0.0.1:6379> multi # 開啟事務

okredis 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

okredis 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 # 監視test

okredis 127.0.0.1:6379> multi # 開啟事務

okredis 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"

Redis事務使用方法 watch

redis事務是一組命令的集合,也是redis的最小執行單位之一。乙個事務的所有命令,要麼都執行,要麼都不執行。redis能保證事務執行期間不會有其他命令插入。命令格式 說明discard discard 取消事務 exec exec 執行事務中的命令 multi multi 標記乙個事務的開始 u...

multi事務 watch命令

本文章是個人筆記,由學習multi okredis sadd user 1 following 2 queued redis sadd user 2 followers 1 queued redis exec 1 integer 1 2 integer 1 上面的 演示了事務的使用方式。首先使用mu...

redis中的watch命令

watch 用於在進行事務操作的最後一步也就是在執行exec 之前對某個key進行監視 如果這個被監視的key被改動,那麼事務就被取消,否則事務正常執行.一般在multi 命令前就用watch命令對某個key進行監控.如果想讓key取消被監控,可以用unwatch命令 被監視的key會被儲存在兩個地...