Redis基礎知識(學習筆記14--發佈/訂閱)

来源:https://www.cnblogs.com/xuliuzai/p/18288239
-Advertisement-
Play Games

《Spark 快速大數據分析》是一本為 Spark 初學者準備的書,它沒有過多深入實現細節,而是更多關註上層用戶的具體用法。不過,本書絕不僅僅限於 Spark 的用法,它對 Spark 的核心概念和基本原理也有較為全面的介紹,讓讀者能夠知其然且知其所以然。 Spark快速大數據分析PDF下載 本書作 ...


一. 發佈/訂閱命令

1.1 消息系統

發佈/訂閱,即pub/sub,是一種消息通信模式:發佈者也稱消息生產者,生產和發送消息到存儲系統;訂閱者也稱為消息消費者,從存儲系統接受和消費消息。這個存儲系統可以是文件系統FS、消息中間件MQ、數據管理系統DBMS,也可以是Redis。整個消息發佈者、訂閱者與存儲系統統稱為消息系統。

消息系統中的訂閱者訂閱了某類消息後,只要存儲系統中存在該類消息,其就可不斷的接受並消費這些消息。當存儲系統中沒有該消息後,訂閱者的接受、消費阻塞。而當發佈者將消息寫入到存儲系統後,會立即喚醒訂閱者。當存儲系統放滿時,不同的發佈者具有不同的處理方式:有的會阻塞發佈者的發佈,等待可用的存儲空間;有的則會將多餘的消息丟失。

當然,不同的消息系統消息的發佈/訂閱方式也是不同的。例如RocketMQ、Kafka等消息中間件構成的消息系統中,發佈/訂閱的消息都是以Topic分類的。而Reids構成的消息系統中,發佈/訂閱的消息都是以頻道Channel分類的。

 1.2 subscibe

SUBSCRIBE channel [channel ...]

redis客戶端通過一個subscibe命令可以同時訂閱任意數量的頻道。在輸出了訂閱了主題後,命令處於阻塞狀態,等待相關頻道的消息。

1.3 pubsubscibe

PSUBSCRIBE pattern [pattern ...]

訂閱一個或多個符合給定模式的頻道。

說明:這裡的模式只能使用通配符*。例如,it*可以匹配所有以it開頭的頻道,像it.news、it.blog、it.tweets等;news.*可以匹配所有以news.開頭的頻道,像news.global.today、news.it等。

1.4 publish

PUBLISH channel message

reids 客戶端將信息 message 發送到指定的頻道 channel 。返回值:接收到信息 message 的訂閱者數量。

1.5 unsubscibe

UNSUBSCRIBE [channel [channel ...]]

redis客戶端退訂給定的頻道。

說明:如果沒有頻道被指定,也即是,一個無參數的 UNSUBSCRIBE 調用被執行,那麼客戶端使用 SUBSCRIBE 命令訂閱的所有頻道都會被退訂。在這種情況下,命令會返回一個信息,告知客戶端所有被退訂的頻道。

1.6 punsubscibe

PUNSUBSCRIBE [pattern [pattern ...]]

退訂一個或多個符合給定模式的頻道。

說明:這裡的模式只能使用通配符*。如果沒有模式被指定,也即是,一個無參數的 PUNSUBSCRIBE 調用被執行,那麼客戶端使用 PSUBSCRIBE 命令訂閱的所有模式都會被退訂。在這種情況下,命令會返回一個信息,告知客戶端所有被退訂的模式。

1.7 pubsub

PUBSUB <subcommand> [argument [argument ...]]

PUBSUB 是一個查看訂閱與發佈系統狀態的內省命令, 它由數個不同格式的子命令組成, 以下將分別對這些子命令進行介紹。

(1)PUBSUB CHANNELS

PUBSUB CHANNELS [pattern]

列出當前的活躍頻道(活躍的意思是有訂閱者的意思)。活躍頻道指的是那些至少有一個訂閱者的頻道, 訂閱模式的客戶端不計算在內。

說明:pattern 參數是可選的。如果不給出 pattern 參數,那麼列出訂閱/發佈系統中的所有活躍頻道。如果給出 pattern 參數,那麼只列出和給定模式 pattern 相匹配的那些活躍頻道。pattern中只能使用通配符*。

(2)PUBSUB NUMSUB

PUBSUB NUMSUB [channel-1 ... channel-N]

返回給定頻道的訂閱者數量, 訂閱模式的客戶端不計算在內。不給定任何頻道,命令只返回一個空列表。

(3)PUBSUB NUMPAT

PUBSUB NUMPAT

返回訂閱模式的數量,所有客戶端訂閱的所有頻道模式的數量總和。 註意, 這個命令返回的不是訂閱模式的客戶端的數量, 而是客戶端訂閱的所有模式的數量總和。返回值為 一個整數回覆(Integer reply)。

二. Redis 事務

Redis的事務的本質是一組命令的批處理。這組命令在執行過程中會被順序地、一次性全部執行完畢,只要沒有出現語法錯誤,這組命令在執行期間是不會被中斷的。

2.1 Redis事務特性

Redis的事務僅保證了數據的一致性,不具有像DBMS一樣的ACID特性。

*** 這組命令中的某些命令的執行失敗不會影響其它命令的執行,不會引發回滾。即不具備原子性。

*** 這組命令通過樂觀鎖機制實現了簡單的隔離性。沒有複雜的隔離級別。

*** 這組命令的執行結果是被寫入到記憶體的,是否持久取決於Redis的持久化策略,與事務無關。

2.2 Redis事務實現

(1)三個命令

Redis事務通過三個命令進行控制。

*** muti:開啟事務。

*** exec:執行事務。

*** discard:取消事務。

(2)基本使用

下麵是定義並執行事務的用法

MULTI

MULTI

標記一個事務塊的開始。事務塊內的多條命令會按照先後順序被放進一個隊列當中,最後由 EXEC 命令原子性(atomic)地執行。返回值,總是返回 OK 。

EXEC

EXEC

執行所有事務塊內的命令。假如某個(或某些) key 正處於 WATCH 命令的監視之下,且事務塊中有和這個(或這些) key 相關的命令,那麼 EXEC 命令只在這個(或這些) key 沒有被其他命令所改動的情況下執行並生效,否則該事務被打斷(abort)。返回值:事務塊內所有命令的返回值,按命令執行的先後順序排列;當操作被打斷時,返回空值 nil 。

DISCARD

DISCARD

取消事務,放棄執行事務塊內的所有命令。如果正在使用 WATCH 命令監視某個(或某些) key,那麼取消所有監視,等同於執行命令 UNWATCH 。返回值總是返回 OK 。

WATCH

WATCH key [key ...]

監視一個(或多個) key ,如果在事務執行之前這個(或這些) key 被其他命令所改動,那麼事務將被打斷。返回值:總是返回 OK 。

這種又稱為 Reids的樂觀鎖,其實現原理依賴是數據記錄的版本號。

UNWATCH

UNWATCH

取消 WATCH 命令對所有 key 的監視。如果在執行 WATCH 命令之後, EXEC 命令或 DISCARD 命令先被執行了的話,那麼就不需要再執行 UNWATCH 了。因為 EXEC 命令會執行事務,因此 WATCH 命令的效果已經產生了;而 DISCARD 命令在取消事務的同時也會取消所有對 key 的監視,因此這兩個命令執行之後,就沒有必要執行 UNWATCH 了。

(3)案例

# 事務被成功執行

redis> MULTI
OK

redis> INCR user_id
QUEUED

redis> INCR user_id
QUEUED

redis> INCR user_id
QUEUED

redis> PING
QUEUED

redis> EXEC
1) (integer) 1
2) (integer) 2
3) (integer) 3
4) PONG


# 監視 key ,且事務成功執行

redis> WATCH lock lock_times
OK

redis> MULTI
OK

redis> SET lock "huangz"
QUEUED

redis> INCR lock_times
QUEUED

redis> EXEC
1) OK
2) (integer) 1


# 監視 key ,且事務被打斷

redis> WATCH lock lock_times
OK

redis> MULTI
OK

redis> SET lock "joe"        # 就在這時,另一個客戶端修改了 lock_times 的值
QUEUED

redis> INCR lock_times
QUEUED

redis> EXEC                  # 因為 lock_times 被修改, joe 的事務執行失敗
(nil)

 

學習參閱聲明

1.【Redis視頻從入門到高級】

https://www.bilibili.com/video/BV1U24y1y7jF?p=11&vd_source=0e347fbc6c2b049143afaa5a15abfc1c】

2. 【Redis 命令參考】

https://haiyong.site/doc/redis/redis-gh-pages/hash/hscan.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 今天發現/usr目錄空間不夠。需要擴展。之前沒有處理過。今天試了一下調整。並且記錄下來整個過程。 1 使用fdisk -l 查看磁碟信息 2、使用fdisk /dev/sda 對磁碟進行分區 操作完後,多了一個/dev/sda3 4 使用 pvcreate /dev/sda3創建物理捲 5、使用vg ...
  • 測試環境中,新搭建的Oracle 19c DG,在主備切換後,新的主庫的告警日誌中一直出現類似下麵這樣的錯誤: .........................................2024-07-08T13:40:55.384302+08:00 rfs (PID:146054): Da ...
  • redis筆記 1. Redis是什麼? Redis( Remote Dictionary Server )是一個使用 C 語言編寫的,高性能非關係型的鍵值對資料庫。 與傳統資料庫不同的是,Redis 的數據是存在記憶體中的,所以讀寫速度非常快,被廣泛應用於緩存方 向。Redis可以將數據寫入磁碟中, ...
  • 各位熱愛Apache DolphinScheduler的小伙伴們,社區6月月報更新啦!這裡將記錄Apache DolphinScheduler社區每月的重要更新,歡迎關註。 月度Merge Stars 感謝以下小伙伴上個月為Apache DolphinScheduler所做的精彩貢獻(排名不分先後) ...
  • 各位熱愛Apache SeaTunnel的小伙伴們,社區6月份月報來啦!這裡將記錄Apache SeaTunnel社區每月的重要更新,歡迎關註。 月度Merge Stars 感謝以下小伙伴上個月為Apache SeaTunnel所做的精彩貢獻(排名不分先後): @baicie,@TaoZex,@lo ...
  • 設想我們在一家很大的互聯網公司做IT方面的規劃、開發和維護,有以下這樣的應用場景: 公司里有若幹個不同的開發團隊,開發語言有Java、.net、Python、C++....十來種,還有很多外包團隊對項目進行開發,大中小系統已經多的數不過來;並且各個團隊、系統間都需要進行海量數據的交換(比如搜索引擎實 ...
  • GaussDB(DWS)成功將Greenplum上數萬個數據模型、數萬個代碼腳本、數百萬行代碼全部遷移至安全可控的數據倉庫平臺。 ...
  • MySql 1. 事務的四大特性? 事務特性ACID:原子性(Atomicity)、一致性(Consistency)、隔離性(Isolation)、持久性(Durability)。 1.原子性是指事務包含的所有操作要麼全部成功,要麼全部失敗回滾。 2.一致性是指一個事務執行之前和執行之後都必須處於一 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 微服務架構已經成為搭建高效、可擴展系統的關鍵技術之一,然而,現有許多微服務框架往往過於複雜,使得我們普通開發者難以快速上手並體驗到微服務帶了的便利。為瞭解決這一問題,於是作者精心打造了一款最接地氣的 .NET 微服務框架,幫助我們輕鬆構建和管理微服務應用。 本框架不僅支持 Consul 服務註 ...
  • 先看一下效果吧: 如果不會寫動畫或者懶得寫動畫,就直接交給Blend來做吧; 其實Blend操作起來很簡單,有點類似於在操作PS,我們只需要設置關鍵幀,滑鼠點來點去就可以了,Blend會自動幫我們生成我們想要的動畫效果. 第一步:要創建一個空的WPF項目 第二步:右鍵我們的項目,在最下方有一個,在B ...
  • Prism:框架介紹與安裝 什麼是Prism? Prism是一個用於在 WPF、Xamarin Form、Uno 平臺和 WinUI 中構建鬆散耦合、可維護和可測試的 XAML 應用程式框架 Github https://github.com/PrismLibrary/Prism NuGet htt ...
  • 在WPF中,屏幕上的所有內容,都是通過畫筆(Brush)畫上去的。如按鈕的背景色,邊框,文本框的前景和形狀填充。藉助畫筆,可以繪製頁面上的所有UI對象。不同畫筆具有不同類型的輸出( 如:某些畫筆使用純色繪製區域,其他畫筆使用漸變、圖案、圖像或繪圖)。 ...
  • 前言 嗨,大家好!推薦一個基於 .NET 8 的高併發微服務電商系統,涵蓋了商品、訂單、會員、服務、財務等50多種實用功能。 項目不僅使用了 .NET 8 的最新特性,還集成了AutoFac、DotLiquid、HangFire、Nlog、Jwt、LayUIAdmin、SqlSugar、MySQL、 ...
  • 本文主要介紹攝像頭(相機)如何採集數據,用於類似攝像頭本地顯示軟體,以及流媒體數據傳輸場景如傳屏、視訊會議等。 攝像頭採集有多種方案,如AForge.NET、WPFMediaKit、OpenCvSharp、EmguCv、DirectShow.NET、MediaCaptre(UWP),網上一些文章以及 ...
  • 前言 Seal-Report 是一款.NET 開源報表工具,擁有 1.4K Star。它提供了一個完整的框架,使用 C# 編寫,最新的版本採用的是 .NET 8.0 。 它能夠高效地從各種資料庫或 NoSQL 數據源生成日常報表,並支持執行複雜的報表任務。 其簡單易用的安裝過程和直觀的設計界面,我們 ...
  • 背景需求: 系統需要對接到XXX官方的API,但因此官方對接以及管理都十分嚴格。而本人部門的系統中包含諸多子系統,系統間為了穩定,程式間多數固定Token+特殊驗證進行調用,且後期還要提供給其他兄弟部門系統共同調用。 原則上:每套系統都必須單獨接入到官方,但官方的接入複雜,還要官方指定機構認證的證書 ...
  • 本文介紹下電腦設備關機的情況下如何通過網路喚醒設備,之前電源S狀態 電腦Power電源狀態- 唐宋元明清2188 - 博客園 (cnblogs.com) 有介紹過遠程喚醒設備,後面這倆天瞭解多了點所以單獨加個隨筆 設備關機的情況下,使用網路喚醒的前提條件: 1. 被喚醒設備需要支持這WakeOnL ...
  • 前言 大家好,推薦一個.NET 8.0 為核心,結合前端 Vue 框架,實現了前後端完全分離的設計理念。它不僅提供了強大的基礎功能支持,如許可權管理、代碼生成器等,還通過採用主流技術和最佳實踐,顯著降低了開發難度,加快了項目交付速度。 如果你需要一個高效的開發解決方案,本框架能幫助大家輕鬆應對挑戰,實 ...