亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2018年10月31日 10:12:31   作者:ImClive  
這篇文章主要介紹了Redis事務涉及的watch、multi等命令,本文給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下

Redis Watch 命令

作用:

 用于監(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 命令

作用:

 用于標記一個事務塊的開始。事務塊內的多條命令會按照先后順序被放進一個隊列當中,最后由 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í)行失敗。這樣調用者在判斷返回值后就可以獲悉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"

總結

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

相關文章

  • redis集合類型_動力節(jié)點Java學院整理

    redis集合類型_動力節(jié)點Java學院整理

    這篇文章給大家介紹了redis集合類型的常用方法,感興趣的朋友參考下吧
    2017-08-08
  • Redis Sentinel的使用方法

    Redis Sentinel的使用方法

    這篇文章主要介紹了Redis Sentinel的使用方法,幫助大家更好的理解和學習使用Redis數(shù)據(jù)庫,感興趣的朋友可以了解下
    2021-03-03
  • Spring+Redis+RabbitMQ開發(fā)限流和秒殺項目功能

    Spring+Redis+RabbitMQ開發(fā)限流和秒殺項目功能

    本項目將通過整合Springboot和Redis以及Lua腳本來實現(xiàn)限流和秒殺的效果,將通過RabbitMQ消息隊列來實現(xiàn)異步保存秒殺結果的效果,對Spring?Redis?RabbitMQ限流秒殺功能實現(xiàn)感興趣的朋友一起看看吧
    2022-02-02
  • 淺談Redis緩存擊穿、緩存穿透、緩存雪崩的解決方案

    淺談Redis緩存擊穿、緩存穿透、緩存雪崩的解決方案

    這篇文章主要介紹了淺談Redis緩存擊穿、緩存穿透、緩存雪崩的解決方案,緩存是分布式系統(tǒng)中的重要組件,主要解決在高并發(fā)、大數(shù)據(jù)場景下,熱點數(shù)據(jù)訪問的性能問題,需要的朋友可以參考下
    2023-03-03
  • Redis生成全局唯一ID的實現(xiàn)方法

    Redis生成全局唯一ID的實現(xiàn)方法

    全局唯一ID生成器是一種在分布式系統(tǒng)下用來生成全局唯一ID的工具,本文主要介紹了Redis生成全局唯一ID的實現(xiàn)方法,具有一定的參考價值,感興趣的可以了解一下
    2022-06-06
  • SpringBoot 開啟Redis緩存及使用方法

    SpringBoot 開啟Redis緩存及使用方法

    用redis做緩存,是因為redis有著很優(yōu)秀的讀寫能力,在集群下可以保證數(shù)據(jù)的高可用,那么今天通過本文給大家講解下SpringBoot使用Redis的緩存的方法,感興趣的朋友一起看看吧
    2021-08-08
  • redis緩存延時雙刪的原因分析

    redis緩存延時雙刪的原因分析

    延時雙刪就是在增刪改某實體類的時候,要對該實體類的緩存進行清空,清空的位置在數(shù)據(jù)庫操作方法的前后,這篇文章主要介紹了redis緩存為什么要延時雙刪,需要的朋友可以參考下
    2022-08-08
  • Redis分布式緩存:微信搶紅包解決方案

    Redis分布式緩存:微信搶紅包解決方案

    微信搶紅包已經在我們生活中很常見的場景了,特別是年底公司開年會和春節(jié)2個時間段。本文主要介紹了通過Redis實現(xiàn)微信搶紅包功能,感興趣的小伙伴可以了解一下
    2021-12-12
  • odoo中使用redis實現(xiàn)緩存的步驟

    odoo中使用redis實現(xiàn)緩存的步驟

    這篇文章主要介紹了odoo中使用redis實現(xiàn)緩存的步驟,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • 詳解Redis如何多規(guī)則限流和防重復提交

    詳解Redis如何多規(guī)則限流和防重復提交

    市面上很多介紹redis如何實現(xiàn)限流的,但是大部分都有一個缺點,就是只能實現(xiàn)單一的限流,但是如果想一個接口兩種規(guī)則都需要滿足呢,使用本文就來介紹一下redis實現(xiàn)分布式多規(guī)則限流的方式吧
    2023-12-12

最新評論