主頁(yè) > 知識(shí)庫(kù) > Redis事務(wù)涉及的watch、multi等命令詳解

Redis事務(wù)涉及的watch、multi等命令詳解

熱門標(biāo)簽:一個(gè)地圖標(biāo)注多少錢 臺(tái)灣電銷 400電話辦理的口碑 南京手機(jī)外呼系統(tǒng)廠家 廊坊外呼系統(tǒng)在哪買 高碑店市地圖標(biāo)注app b2b外呼系統(tǒng) 地圖標(biāo)注工廠入駐 四川穩(wěn)定外呼系統(tǒng)軟件

Redis Watch 命令

作用:

 用于監(jiān)視一個(gè)(或多個(gè)) key ,如果在事務(wù)執(zhí)行之前這個(gè)(或這些) key 被其他命令所改動(dòng),那么事務(wù)將被打斷。

 用法:

redis 127.0.0.1:6379> WATCH key1 key2

OK

Redis Unwatch 命令

作用:

 用于取消 WATCH 命令對(duì)所有 key 的監(jiān)視。

 用法:

redis 127.0.0.1:6379> UNWATCH

OK

Redis Multi 命令

作用:

 用于標(biāo)記一個(gè)事務(wù)塊的開(kāi)始。事務(wù)塊內(nèi)的多條命令會(huì)按照先后順序被放進(jìn)一個(gè)隊(duì)列當(dāng)中,最后由 EXEC 命令原子性(atomic)地執(zhí)行。

 用法:

redis 127.0.0.1:6379> MULTI      # 標(biāo)記事務(wù)開(kāi)始
OK
redis 127.0.0.1:6379> INCR user_id   # 多條命令按順序入隊(duì)
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實(shí)現(xiàn)incr

具體做法如下:

   WATCH mykey
   val = GET mykey
   val = val + 1
   MULTI
   SET mykey $val
   EXEC

在獲取mykey的值之前先通過(guò)WATCH命令監(jiān)控了該鍵,此后又將set命令包圍在事務(wù)中,這樣就可以有效的保證每個(gè)連接在執(zhí)行EXEC之前,如果當(dāng)前連接獲取的mykey的值被其它連接的客戶端修改,那么當(dāng)前連接的EXEC命令將執(zhí)行失敗。這樣調(diào)用者在判斷返回值后就可以獲悉val是否被重新設(shè)置成功。

注意點(diǎn):

•由于WATCH命令的作用只是當(dāng)被監(jiān)控的鍵值被修改后阻止之后一個(gè)事務(wù)的執(zhí)行,而不能保證其他客戶端不修改這一鍵值,所以在一般的情況下我們需要在EXEC執(zhí)行失敗后重新執(zhí)行整個(gè)函數(shù)。
•執(zhí)行EXEC命令后會(huì)取消對(duì)所有鍵的監(jiān)控,如果不想執(zhí)行事務(wù)中的命令也可以使用UNWATCH命令來(lái)取消監(jiān)控。

示例:

打開(kāi)兩個(gè)redis-cli命令行窗口 session 1 和 session 2

session 1:
redis 127.0.0.1:6379> set test 1  # 設(shè)置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    # 開(kāi)啟事務(wù)
OK
redis 127.0.0.1:6379> set test 2  # 將test設(shè)為"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 中所設(shè)置的"3"
"3"
redis 127.0.0.1:6379> unwatch   # 取消監(jiān)視所有key
OK
redis 127.0.0.1:6379> set test 4  # 非事務(wù)變更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    # 開(kāi)啟事務(wù)
OK
redis 127.0.0.1:6379> set test 3 # 將test設(shè)為"3"
QUEUED
redis 127.0.0.1:6379> exec    # 執(zhí)行事務(wù)
1) OK
redis 127.0.0.1:6379> get test  # 獲取到test="3"
"3"

總結(jié)

以上所述是小編給大家介紹的Redis事務(wù)涉及的watch、multi等命令,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • PHP+Redis事務(wù)解決高并發(fā)下商品超賣問(wèn)題(推薦)
  • redis中的事務(wù)操作案例分析
  • redis事務(wù)常用操作詳解
  • python實(shí)現(xiàn)redis三種cas事務(wù)操作
  • redis中事務(wù)機(jī)制及樂(lè)觀鎖的實(shí)現(xiàn)
  • redis事務(wù)_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
  • Redis 基礎(chǔ)教程之事務(wù)的使用方法
  • Redis 事務(wù)與過(guò)期時(shí)間詳細(xì)介紹
  • 【Redis緩存機(jī)制】詳解Java連接Redis_Jedis_事務(wù)
  • Redis教程(八):事務(wù)詳解
  • Redis 事務(wù)知識(shí)點(diǎn)相關(guān)總結(jié)

標(biāo)簽:南寧 泰州 拉薩 河源 定州 畢節(jié) 伊春 甘南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Redis事務(wù)涉及的watch、multi等命令詳解》,本文關(guān)鍵詞  Redis,事務(wù),涉及,的,watch,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Redis事務(wù)涉及的watch、multi等命令詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Redis事務(wù)涉及的watch、multi等命令詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章