校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Redis事務涉及的watch、multi等命令詳解

Redis事務涉及的watch、multi等命令詳解

熱門標簽:一個地圖標注多少錢 臺灣電銷 400電話辦理的口碑 南京手機外呼系統廠家 廊坊外呼系統在哪買 高碑店市地圖標注app b2b外呼系統 地圖標注工廠入駐 四川穩定外呼系統軟件

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"

總結

以上所述是小編給大家介紹的Redis事務涉及的watch、multi等命令,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

您可能感興趣的文章:
  • PHP+Redis事務解決高并發下商品超賣問題(推薦)
  • redis中的事務操作案例分析
  • redis事務常用操作詳解
  • python實現redis三種cas事務操作
  • redis中事務機制及樂觀鎖的實現
  • redis事務_動力節點Java學院整理
  • Redis 基礎教程之事務的使用方法
  • Redis 事務與過期時間詳細介紹
  • 【Redis緩存機制】詳解Java連接Redis_Jedis_事務
  • Redis教程(八):事務詳解
  • Redis 事務知識點相關總結

標簽:南寧 泰州 拉薩 河源 定州 畢節 伊春 甘南

巨人網絡通訊聲明:本文標題《Redis事務涉及的watch、multi等命令詳解》,本文關鍵詞  Redis,事務,涉及,的,watch,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Redis事務涉及的watch、multi等命令詳解》相關的同類信息!
  • 本頁收集關于Redis事務涉及的watch、multi等命令詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 广平县| 车险| 阳朔县| 中西区| 灵武市| 武夷山市| 称多县| 丰宁| 白银市| 宾阳县| 芦溪县| 哈密市| 桓台县| 罗城| 汶川县| 巨鹿县| 离岛区| 兰考县| 临夏市| 澳门| 崇文区| 大宁县| 陇西县| 临沧市| 石嘴山市| 辽宁省| 淮北市| 平塘县| 仪陇县| 沈阳市| 横峰县| 黄龙县| 阿拉尔市| 江源县| 专栏| 米脂县| 安塞县| 卢湾区| 建瓯市| 临洮县| 天台县|