日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

redis以內存數據庫而聞名。但是,某些系統將它用作消息隊列管理工具。

Pub/Sub 和 RPOPLPUSH 是用于實現這樣一個系統的兩組命令。在這篇文章中,我將分享一些關于這兩個命令集的知識,它們的用例以及優缺點。

Redis消息隊列:RPOPLPUSH vs Pub/Sub

 

PUBLISH/SUBSCRIBE

假設 Pub/Sub 就像一個無線電臺,所有訂閱隊列的使用者都將接收發布到該隊列的所有消息。

它是如何工作的

消費者 C1、C2、C3 訂閱隊列 q

生產者 P 將消息m發布到隊列 q

隊列 q 向所有消費者 C1、C2、C3 發送消息

Redis消息隊列:RPOPLPUSH vs Pub/Sub

 

例子

群聊系統是這種消息隊列類型的典型例子,其中用戶向一個組發送消息,所有其他組成員都需要接收該消息。Pub/Sub 是一個很好的工具,可以確保消息傳遞給所有訂閱者。

什么時候不使用

由于內存緩沖區的效率,如果消費者失去了與隊列的連接,那么消費者很有可能在連接丟失時丟失消息。Redis服務器決定清除消息緩沖區,為下一個傳入的消息節省更多的內存。

RPOPLPUSH

RPOPLPUSH(可靠隊列模式)的工作方式不同。消息隊列管理的實現來自客戶機,而不是Redis服務器。

它是如何工作的

隊列 q 是 Redis 中的一個列表。

生產者 P LPUSH 消息 m1, m2, m3 到列表 q。

消費者 C1 通過使用命令 RPOPLPUSH 從列表 q 中彈出消息 m1 來消費來自列表 q 的消息,同時將該消息推送到另一個工作列表 q-c1-working。

如果 C1 成功使用 m1,它會將消息 m1 從工作列表 q-c1-working 中刪除。

如果 C1 未能使用該消息,根據業務邏輯,它將:消息 m1 重新排隊到原始隊列 q 或者拒絕消息 m1,將其移動到拒絕隊列 q-rejected。

消費者 C2、C3 依次處理與 C1 相同的流中的消息,但處理的消息不同。只有一個使用者成功地使用了一個特定的消息。

Redis消息隊列:RPOPLPUSH vs Pub/Sub

 

例子

這種機制在一個消息被一個且只有一個消費者成功消費的情況下非常有用。

什么時候不使用

此過程至少創建 3 個隊列:主隊列、工作隊列、拒絕隊列。此外,每個消費者都有自己的工作隊列。當查看隊列列表時,有點錯綜復雜。

分享到:
標簽:隊列 消息 Redis
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定