redis Watch 命令
成都創(chuàng)新互聯(lián)自2013年起,是專業(yè)互聯(lián)網(wǎng)技術服務公司,擁有項目成都網(wǎng)站設計、網(wǎng)站制作網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元通化縣做網(wǎng)站,已為上家服務,為通化縣各地企業(yè)和個人服務,聯(lián)系電話:18982081108
作用:
用于監(jiān)視一個(或多個) key ,如果在事務執(zhí)行之前這個(或這些) key 被其他命令所改動,那么事務將被打斷。
用法:
redis 127.0.0.1:6379> WATCH key1 key2
OK
Redis Unwatch 命令
作用:
用于取消 WATCH 命令對所有 key 的監(jiān)視。
用法:
redis 127.0.0.1:6379> UNWATCH
OK
Redis Multi 命令
作用:
用于標記一個事務塊的開始。事務塊內(nèi)的多條命令會按照先后順序被放進一個隊列當中,最后由 EXEC 命令原子性(atomic)地執(zhí)行。
用法:
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 # 執(zhí)行 1) (integer) 1 2) (integer) 2 3) (integer) 3 4) PONG
利用watch實現(xiàn)incr
具體做法如下:
WATCH mykey val = GET mykey val = val + 1 MULTI SET mykey $val EXEC
在獲取mykey的值之前先通過WATCH命令監(jiān)控了該鍵,此后又將set命令包圍在事務中,這樣就可以有效的保證每個連接在執(zhí)行EXEC之前,如果當前連接獲取的mykey的值被其它連接的客戶端修改,那么當前連接的EXEC命令將執(zhí)行失敗。這樣調(diào)用者在判斷返回值后就可以獲悉val是否被重新設置成功。
注意點:
•由于WATCH命令的作用只是當被監(jiān)控的鍵值被修改后阻止之后一個事務的執(zhí)行,而不能保證其他客戶端不修改這一鍵值,所以在一般的情況下我們需要在EXEC執(zhí)行失敗后重新執(zhí)行整個函數(shù)。
•執(zhí)行EXEC命令后會取消對所有鍵的監(jiān)控,如果不想執(zhí)行事務中的命令也可以使用UNWATCH命令來取消監(jiān)控。
示例:
打開兩個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 # 監(jiān)視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 執(zhí)行完畢后再執(zhí)行 session 1 的exec命令,發(fā)現(xiàn)執(zhí)行失敗 (nil) redis 127.0.0.1:6379> get test # 獲取test的值,發(fā)現(xiàn)test值為 session 2 中所設置的"3" "3" redis 127.0.0.1:6379> unwatch # 取消監(jiān)視所有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 創(chuàng)建的test="1" "1" redis 127.0.0.1:6379> watch test # 監(jiān)視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 # 執(zhí)行事務 1) OK redis 127.0.0.1:6379> get test # 獲取到test="3" "3"
總結(jié)
以上所述是小編給大家介紹的Redis事務涉及的watch、multi等命令,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!
當前文章:Redis事務涉及的watch、multi等命令詳解
鏈接分享:http://aaarwkj.com/article22/ipdjjc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、面包屑導航、外貿(mào)建站、品牌網(wǎng)站建設、App開發(fā)、品牌網(wǎng)站設計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)