精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

一口氣說出六種實現延時消息的方案

開發 后端
本文匯總了目前業界常見的延時消息方案,并且討論了各個方案的優缺點。希望對讀者有所啟發。

前言

延時消息(定時消息)指的在分布式異步消息場景下,生產端發送一條消息,希望在指定延時或者指定時間點被消費端消費到,而不是立刻被消費。

延時消息適用的業務場景非常的廣泛,在分布式系統環境下,延時消息的功能一般會在下沉到中間件層,通常是 MQ 中內置這個功能或者內聚成一個公共基礎服務。

本文旨在探討常見延時消息的實現方案以及方案設計的優缺點。

實現方案

1.基于外部存儲實現的方案

這里討論的外部存儲指的是在 MQ 本身自帶的存儲以外又引入的其他的存儲系統。

基于外部存儲的方案本質上都是一個套路,將 MQ 和 延時模塊 區分開來,延時消息模塊是一個獨立的服務/進程。延時消息先保留到其他存儲介質中,然后在消息到期時再投遞到 MQ。

當然還有一些細節性的設計,比如消息進入的延時消息模塊時已經到期則直接投遞這類的邏輯,這里不展開討論。

下述方案不同的是,采用了不同的存儲系統。

基于 數據庫(如MySQL)

基于關系型數據庫(如MySQL)延時消息表的方式來實現。

CREATE TABLE `delay_msg` (
`id` bigint unsigned NOT NULL AUTO_INCREMENT,
`delivery_time` DATETIME NOT NULL COMMENT '投遞時間',
`payloads` blob COMMENT '消息內容',
PRIMARY KEY (`id`),
KEY `time_index` (`delivery_time`)
)

通過定時線程定時掃描到期的消息,然后進行投遞。定時線程的掃描間隔理論上就是你延時消息的最小時間精度。

優點:

  • 實現簡單;

缺點:

  • B+Tree索引不適合消息場景的大量寫入;

基于 RocksDB

RocksDB 的方案其實就是在上述方案上選擇了比較合適的存儲介質。

RocksDB 在筆者之前的文章中有聊過,LSM 樹更適合大量寫入的場景。滴滴開源的DDMQ中的延時消息模塊 Chronos 就是采用了這個方案。

DDMQ 這個項目簡單來說就是在 RocketMQ 外面加了一層統一的代理層,在這個代理層就可以做一些功能維度的擴展。延時消息的邏輯就是代理層實現了對延時消息的轉發,如果是延時消息,會先投遞到 RocketMQ 中 Chronos 專用的 topic 中。

延時消息模塊 Chronos 消費得到延時消息轉儲到 RocksDB,后面就是類似的邏輯了,定時掃描到期的消息,然后往 RocketMQ 中投遞。

這個方案老實說是一個比較重的方案。因為基于 RocksDB 來實現的話,從數據可用性的角度考慮,你還需要自己去處理多副本的數據同步等邏輯。

優點:

  • RocksDB LSM 樹很適合消息場景的大量寫入;

缺點:

  • 實現方案較重,如果你采用這個方案,需要自己實現 RocksDB 的數據容災邏輯;

基于 Redis

再來聊聊 Redis 的方案。下面放一個比較完善的方案。

  • Messages Pool 所有的延時消息存放,結構為KV結構,key為消息ID,value為一個具體的message(這里選擇Redis Hash結構主要是因為hash結構能存儲較大的數據量,數據較多時候會進行漸進式rehash擴容,并且對于HSET和HGET命令來說時間復雜度都是O(1))
  • Delayed Queue是16個有序隊列(隊列支持水平擴展),結構為ZSET,value 為 messages pool中消息ID,score為過期時間(分為多個隊列是為了提高掃描的速度)
  • Worker 代表處理線程,通過定時任務掃描 Delayed Queue 中到期的消息

這個方案選用 Redis 存儲在我看來有幾點考慮,

  • Redis ZSET 很適合實現延時隊列
  • 性能問題,雖然 ZSET 插入是一個 O(logn) 的操作,但是Redis 基于內存操作,并且內部做了很多性能方面的優化。

但是這個方案其實也有需要斟酌的地方,上述方案通過創建多個 Delayed Queue 來滿足對于并發性能的要求,但這也帶來了多個 Delayed Queue 如何在多個節點情況下均勻分配,并且很可能出現到期消息并發重復處理的情況,是否要引入分布式鎖之類的并發控制設計?

在量不大的場景下,上述方案的架構其實可以蛻化成主從架構,只允許主節點來處理任務,從節點只做容災備份。實現難度更低更可控。

定時線程檢查的缺陷與改進

上述幾個方案中,都通過線程定時掃描的方案來獲取到期的消息。

定時線程的方案在消息量較少的時候,會浪費資源,在消息量非常多的時候,又會出現因為掃描間隔設置不合理導致延時時間不準確的問題。可以借助 JDK Timer 類中的思想,通過 wait-notify 來節省 CPU 資源。

獲取中最近的延時消息,然后wait(執行時間-當前時間),這樣就不需要浪費資源到達時間時會自動響應,如果有新的消息進入,并且比我們等待的消息還要小,那么直接notify喚醒,重新獲取這個更小的消息,然后又wait,如此循環。

2. 開源 MQ 中的實現方案

再來講講目前自帶延時消息功能的開源MQ,它們是如何實現的

RocketMQ

RocketMQ 開源版本支持延時消息,但是只支持 18 個 Level 的延時,并不支持任意時間。只不過這個 Level 在 RocketMQ 中可以自定義的,所幸來說對普通業務算是夠用的。默認值為“1s 5s 10s 30s 1m 2m 3m 4m 5m 6m 7m 8m 9m 10m 20m 30m 1h 2h”,18個level。

通俗的講,設定了延時 Level 的消息會被暫存在名為SCHEDULE_TOPIC_XXXX的topic中,并根據 level 存入特定的queue,queueId = delayTimeLevel – 1,即一個queue只存相同延時的消息,保證具有相同發送延時的消息能夠順序消費。 broker會調度地消費SCHEDULE_TOPIC_XXXX,將消息寫入真實的topic。

下面是整個實現方案的示意圖,紅色代表投遞延時消息,紫色代表定時調度到期的延時消息:

優點:

  • Level 數固定,每個 Level 有自己的定時器,開銷不大
  • 將 Level 相同的消息放入到同一個 Queue 中,保證了同一 Level 消息的順序性;不同 Level 放到不同的 Queue 中,保證了投遞的時間準確性;
  • 通過只支持固定的Level,將不同延時消息的排序變成了固定Level Topic 的追加寫操作

缺點:

  • Level 配置的修改代價太大,固定 Level 不靈活
  • CommitLog 會因為延時消息的存在變得很大

Pulsar

Pulsar 支持“任意時間”的延時消息,但實現方式和 RocketMQ 不同。

通俗的講,Pulsar 的延時消息會直接進入到客戶端發送指定的 Topic 中,然后在堆外內存中創建一個基于時間的優先級隊列,來維護延時消息的索引信息。延時時間最短的會放在頭上,時間越長越靠后。在進行消費邏輯時候,再判斷是否有到期需要投遞的消息,如果有就從隊列里面拿出,根據延時消息的索引查詢到對應的消息進行消費。

如果節點崩潰,在這個 broker 節點上的 Topics 會轉移到其他可用的 broker 上,上面提到的這個優先級隊列也會被重建。

下面是 Pulsar 公眾號中對于 Pulsar 延時消息的示意圖。

乍一看會覺得這個方案其實非常簡單,還能支持任意時間的消息。但是這個方案有幾個比較大的問題

  • 內存開銷: 維護延時消息索引的隊列是放在堆外內存中的,并且這個隊列是以訂閱組(Kafka中的消費組)為維度的,比如你這個 Topic 有 N 個訂閱組,那么如果你這個 Topic 使用了延時消息,就會創建 N 個 隊列;并且隨著延時消息的增多,時間跨度的增加,每個隊列的內存占用也會上升。(是的,在這個方案下,支持任意的延時消息反而有可能讓這個缺陷更嚴重)
  • 故障轉移之后延時消息索引隊列的重建時間開銷: 對于跨度時間長的大規模延時消息,重建時間可能會到小時級別。(摘自 Pulsar 官方公眾號文章)
  • 存儲開銷: 延時消息的時間跨度會影響到 Pulsar 中已經消費的消息數據的空間回收。打個比方,你的 Topic 如果業務上要求支持一個月跨度的延時消息,然后你發了一個延時一個月的消息,那么你這個 Topic 中底層的存儲就會保留整整一個月的消息數據,即使這一個月中99%的正常消息都已經消費了。

對于前面第一點和第二點的問題,社區也設計了解決方案,在隊列中加入時間分區,Broker 只加載當前較近的時間片的隊列到內存,其余時間片分區持久化磁盤,示例圖如下圖所示:

但是目前,這個方案并沒有對應的實現版本。可以在實際使用時,規定只能使用較小時間跨度的延時消息,來減少前兩點缺陷的影響。另外,因為內存中存的并不是延時消息的全量數據,只是索引,所以可能要積壓上百萬條延時消息才可能對內存造成顯著影響,從這個角度來看,官方暫時沒有完善前兩個問題也可以理解了。

至于第三個問題,估計是比較難解決的,需要在數據存儲層將延時消息和正常消息區分開來,單獨存儲延時消息。

QMQ

QMQ提供任意時間的延時/定時消息,你可以指定消息在未來兩年內(可配置)任意時間內投遞。

把 QMQ 放到最后,是因為我覺得 QMQ 是目前開源 MQ 中延時消息設計最合理的。里面設計的核心簡單來說就是 多級時間輪 + 延時加載 + 延時消息單獨磁盤存儲。

QMQ的延時/定時消息使用的是兩層 hash wheel 來實現的。第一層位于磁盤上,每個小時為一個刻度(默認為一個小時一個刻度,可以根據實際情況在配置里進行調整),每個刻度會生成一個日志文件(schedule log),因為QMQ支持兩年內的延時消息(默認支持兩年內,可以進行配置修改),則最多會生成 2 * 366 * 24 = 17568 個文件(如果需要支持的最大延時時間更短,則生成的文件更少)。

第二層在內存中,當消息的投遞時間即將到來的時候,會將這個小時的消息索引(索引包括消息在schedule log中的offset和size)從磁盤文件加載到內存中的hash wheel上,內存中的hash wheel則是以500ms為一個刻度。

總結一下設計上的亮點:

  • 時間輪算法適合延時/定時消息的場景,省去延時消息的排序,插入刪除操作都是 O(1) 的時間復雜度;
  • 通過多級時間輪設計,支持了超大時間跨度的延時消息;
  • 通過延時加載,內存中只會有最近要消費的消息,更久的延時消息會被存儲在磁盤中,對內存友好;
  • 延時消息單獨存儲(schedule log),不會影響到正常消息的空間回收;

總結

本文匯總了目前業界常見的延時消息方案,并且討論了各個方案的優缺點。希望對讀者有所啟發。

責任編輯:龐桂玉 來源: Java知音
相關推薦

2020-04-14 13:32:56

@Transacti失效場景

2020-03-31 08:12:25

Kafka架構數據庫

2020-05-08 10:08:21

延時隊列APIDelayQueue

2020-09-24 09:08:04

分布式系統架構

2020-07-08 07:45:44

OAuth2.0授權

2020-04-16 12:42:42

附近的人共享單車App

2020-08-12 09:55:07

附近的人數據庫MySQL

2021-06-08 22:43:07

IPC方式Qt

2020-07-10 07:44:26

Session方式Web

2022-05-24 10:43:02

延時消息分布式MQ

2021-12-06 08:30:49

SpringSpring Bean面試題

2025-05-14 01:55:00

FCMCPAI

2021-03-29 12:22:25

微信iOS蘋果

2020-07-31 10:15:32

分布式ID數據庫MySQL

2020-11-04 14:20:58

分布式數據庫MySQL

2023-12-18 23:09:25

開源優化引擎

2020-10-22 12:30:33

MySQL

2024-03-26 09:42:27

分片算法應用

2025-11-11 08:47:00

2020-06-04 07:45:07

過濾器和攔截器
點贊
收藏

51CTO技術棧公眾號

国产三区在线成人av| 中文字幕一区二区三三| 日本久久精品电影| 亚洲国产精品一区在线观看不卡| 国产美女www爽爽爽视频| 国产精品久久| 中文字幕国产亚洲2019| 乳色吐息在线观看| 成人亚洲欧美| 亚洲最新视频在线观看| 奇米影视首页 狠狠色丁香婷婷久久综合 | 污视频在线观看免费网站| 爱啪视频在线观看视频免费| 欧美激情中文字幕一区二区| 国产亚洲精品自在久久| 亚洲一区二区人妻| 国产精品一区亚洲| 欧美成人精品三级在线观看| 丰满少妇一区二区| 超碰成人97| 91精品久久久久久久99蜜桃| 亚洲中文字幕无码不卡电影| 亚洲按摩av| 国产精品国产三级国产aⅴ无密码| 国产在线一区二区三区四区| 国产精品午夜福利| 青青青伊人色综合久久| 2019中文在线观看| 久久久香蕉视频| 亚洲欧美日韩高清在线| 一区二区三区www| 鲁大师私人影院在线观看| 亚洲1区在线观看| 欧美日韩视频在线一区二区| 两根大肉大捧一进一出好爽视频| 狂野欧美性猛交xxxxx视频| 国产精品久久久久天堂| 日产精品一线二线三线芒果| 视频在线观看你懂的| 国产·精品毛片| 147欧美人体大胆444| 96日本xxxxxⅹxxx17| 免费看欧美美女黄的网站| 国产999精品久久久影片官网| 日韩高清精品免费观看| 亚洲一级影院| 欧美精品18videos性欧美| 欧美毛片在线观看| 欧美精品97| 欧美成人精品激情在线观看| 激情综合五月网| 欧美黄色一级视频| 欧美激情区在线播放| 国产极品国产极品| 欧美精品激情| 欧美精品videosex极品1| 久草免费在线视频观看| 激情久久中文字幕| 91av在线不卡| 亚洲欧美自拍视频| 久久精品人人做人人爽电影蜜月| 日本不卡高字幕在线2019| 好吊色在线视频| 日本va欧美va精品发布| 国产精品亚洲网站| 国产女人18毛片水真多| 国产suv精品一区二区6| 国产高清一区二区三区| 香蕉久久国产av一区二区| 久久众筹精品私拍模特| 亚洲国产日韩欧美| a级网站在线播放| 亚洲成人自拍网| 青青草原av在线播放| 国精产品一区一区三区四川| 欧美人与性动xxxx| 韩国三级hd中文字幕有哪些| 国产一区二区在线视频你懂的| 国产丝袜精品第一页| 手机看片日韩av| 中文字幕一区二区三区久久网站| 午夜精品理论片| 免费精品一区二区| 国产精品 欧美精品| 久久久水蜜桃| 激情在线小视频| 精品国产老师黑色丝袜高跟鞋| 国产成人精品视频ⅴa片软件竹菊| 久久69成人| 亚洲精品一区二区三区影院| 六月婷婷七月丁香| 91精品成人| 欧美有码在线观看| 国产免费不卡av| 91丨九色丨国产丨porny| 亚洲人成网站在线播放2019| 波多野结衣在线播放| 在线免费观看日韩欧美| 亚洲免费观看在线| 国内精品久久久久久99蜜桃| 欧美激情在线播放| 中文字幕视频一区二区| 99精品视频在线播放观看| 亚洲一二三区精品| 在线高清av| 日韩免费看网站| 91视频免费看片| 国产精品久久久久久久久久妞妞 | 欧美日韩黄色| 亚洲偷欧美偷国内偷| 国产小视频在线看| 久久精品久久综合| 欧美日本韩国国产| 国产丝袜精品丝袜| 3d成人h动漫网站入口| 一本色道久久综合亚洲精品图片| 午夜欧美精品久久久久久久| 国产免费一区二区三区在线能观看 | 亚洲二区自拍| 夜鲁夜鲁夜鲁视频在线播放| 精品国产亚洲在线| www深夜成人a√在线| 久久性色av| 久久久国产精品一区二区三区| 黄色免费在线看| 欧美日韩三级一区二区| 熟女少妇一区二区三区| 亚洲青涩在线| av免费观看久久| 麻豆传媒在线完整视频| 欧美三日本三级三级在线播放| 国产老熟女伦老熟妇露脸| 国产在线成人| 亚洲综合一区二区不卡| 精品视频在线一区二区| 欧美乱熟臀69xxxxxx| 成人无码av片在线观看| 天堂精品中文字幕在线| 欧美13一14另类| 中文在线8资源库| 日韩久久免费电影| 国产无遮挡呻吟娇喘视频| 成人涩涩免费视频| www.国产在线视频| swag国产精品一区二区| 久久久久久久电影一区| 成 人 黄 色 片 在线播放| 亚洲女人小视频在线观看| 思思久久精品视频| 91精品观看| 亚洲淫片在线视频| 免费污视频在线观看| 欧美不卡123| 国产午夜精品一区二区理论影院 | 欧美在线观看视频一区二区三区| 欧美多人猛交狂配| 日韩在线一区二区| 亚洲国产一区二区三区在线| 欧美日韩视频免费看| 色妞一区二区三区| 国产喷水福利在线视频| 一区二区三区在线观看动漫| 亚洲少妇一区二区三区| 日韩一级在线| 日本一区免费观看| 日本国产一区| 欧美精品一本久久男人的天堂| 亚洲经典一区二区三区| 香蕉久久一区二区不卡无毒影院 | 亚洲国产日韩在线观看| 精品人伦一区二区三区蜜桃网站| 97人妻精品一区二区三区免| 三级在线观看一区二区| 亚洲一区二区三区乱码| 日韩欧美一级| 欧洲一区二区视频| 一级毛片视频在线观看| 日韩女优制服丝袜电影| 国产免费av一区二区| 中文无字幕一区二区三区 | 美女黄页在线观看| 亚洲女女做受ⅹxx高潮| 精品中文字幕在线播放| 麻豆一区二区三| 久久久久久久9| 国产精品一线天粉嫩av| 亚洲最大的成人网| 韩漫成人漫画| 欧美成人免费全部观看天天性色| 五月天激情开心网| 欧美精品在线一区二区三区| 日韩黄色精品视频| 国产精品久久久久久久岛一牛影视| 少妇伦子伦精品无吗| 久久中文精品| 欧美在线观看视频免费| 国产精品亚洲人成在99www| 91视频免费进入| 日韩不卡在线| 97色在线视频观看| 91caoporm在线视频| 欧美精品一区在线观看| 国产又粗又猛又黄| 精品国产成人在线| 欧美一区二区三区爽爽爽| 久久视频一区二区| 在线播放第一页| 美女免费视频一区| 久久久久久久激情| 韩国av一区| 手机在线视频你懂的| 少妇精品久久久| 国产精品日韩一区二区| japansex久久高清精品| 国产精品wwww| 欧美特大特白屁股xxxx| 午夜精品久久久久久久99黑人 | 国色天香2019中文字幕在线观看| 欧美日韩xx| 国产亚洲欧美日韩精品| 天堂在线一二区| 亚洲第一色在线| 亚洲第一色网站| 日韩一级高清毛片| 国产又粗又黄又爽的视频| 在线国产电影不卡| 久久久精品视频网站| 黄色一区二区三区| 久久精品视频6| 一级日本不卡的影视| 国产色无码精品视频国产| 国产精品拍天天在线| xxxx日本黄色| 欧美激情一区二区三区四区| 黄瓜视频污在线观看| 91污在线观看| 一二三不卡视频| 久久综合精品国产一区二区三区 | 99热这里只有精品3| 欧美情侣在线播放| 91精品国产综合久| 欧美日韩国产电影| 一区二区精品视频在线观看| 欧美在线观看禁18| 夜夜爽8888| 91精品免费观看| aa视频在线免费观看| 日韩小视频在线观看专区| 国产伦精品一区二区三区免.费| 欧美二区在线观看| av天堂一区二区三区| 欧美大黄免费观看| 天堂在线视频免费观看| 亚洲精品99久久久久| 日韩av成人| 国产亚洲日本欧美韩国| 永久av在线| 欧美日韩成人在线播放| 高h视频在线播放| 18久久久久久| 日韩av超清在线观看| 成人免费激情视频| 欧美久久亚洲| 九色一区二区| 欧美精品一区二区三区精品| 亚洲伊人婷婷| 欧美另类女人| 干日本少妇首页| 青青青爽久久午夜综合久久午夜| 伊人成人222| 粉嫩一区二区三区在线看| 欧美一级片黄色| 国产区在线观看成人精品| 亚洲女人久久久| 亚洲综合一区二区精品导航| 久久久久99精品成人片三人毛片| 在线免费观看日本一区| 国产特级黄色片| 亚洲国产日韩欧美在线图片| 国产美女视频一区二区三区| 久久久成人精品视频| 国产h片在线观看| 国产精品偷伦视频免费观看国产| 日韩最新av| 欧美亚洲另类久久综合| 97精品视频在线看| 日韩中文字幕在线免费| 青草av.久久免费一区| 欧美图片自拍偷拍| 日本一区二区久久| 国产一级一级片| 在线免费观看一区| 少妇精品视频一区二区| 伊人亚洲福利一区二区三区| 日本小视频在线免费观看| 日韩免费av在线| xvideos.蜜桃一区二区| 日韩欧美视频一区二区三区四区| 国产精品多人| 亚洲综合不卡| 日本美女视频一区| 91免费国产在线| 人妻久久一区二区| 在线观看av一区二区| 韩国av免费在线| 色青青草原桃花久久综合| 久久久男人天堂| 3d蒂法精品啪啪一区二区免费| 蜜乳av综合| 欧美一级欧美一级| 精品一区二区三区影院在线午夜 | 久久综合久久久久88| 妺妺窝人体色www婷婷| 欧美日韩免费视频| 日韩av资源| 国内精品久久久久久中文字幕| 日本久久一区| 婷婷久久伊人| 久久精品系列| 国产精品久久AV无码| 一区二区理论电影在线观看| 97国产成人无码精品久久久| 国产亚洲精品成人av久久ww| 91吃瓜在线观看| 都市激情久久久久久久久久久| 999久久久亚洲| 欧美精品久久久久久久久25p| 91美女在线观看| 青青草av在线播放| 亚洲成av人乱码色午夜| 怡红院在线观看| 亚洲一区二区三区xxx视频| 日韩免费在线| 三级视频中文字幕| 中文字幕国产一区| 自拍偷拍第八页| 中文字幕日韩av综合精品| 忘忧草在线www成人影院| 久久久久se| 午夜亚洲激情| 免费无码一区二区三区| 午夜精品123| 五月婷婷六月色| 欧美与欧洲交xxxx免费观看| 视频小说一区二区| 日本黄网站免费| 国产亚洲综合色| 中文在线资源天堂| 在线中文字幕日韩| 欧美日韩va| 日韩一级免费看| 不卡av电影在线播放| 国产精品黄色网| 亚洲欧美一区二区三区情侣bbw | 国产传媒在线播放| 91网免费观看| 在线日韩电影| 在线免费观看日韩av| 在线免费精品视频| 久草免费在线| 国产视频在线观看一区| 国产精品日韩| av电影网站在线观看| 欧美日产国产精品| 性欧美高清come| 精品一区二区三区国产| 视频在线在亚洲| 五月天色婷婷丁香| 精品播放一区二区| 不卡av影片| 在线亚洲美日韩| 懂色av中文字幕一区二区三区| 欧美bbbbbbbbbbbb精品| 影音先锋欧美精品| 国产不卡精品在线| 成人午夜精品久久久久久久蜜臀| 久久午夜色播影院免费高清| 在线观看中文字幕码| 欧美黑人视频一区| 国产成人黄色| 中文字幕无码毛片免费看| 黑人与娇小精品av专区| 在线观看免费网站黄| 国产成人看片| 日本伊人精品一区二区三区观看方式| 午夜国产福利一区二区| 精品亚洲精品福利线在观看| 亚洲热av色在线播放| 狠狠干 狠狠操| 国产精品久久久爽爽爽麻豆色哟哟| 精品人妻午夜一区二区三区四区 | 一区二区自拍偷拍| 国内精品在线一区| 日韩理论电影| 国产夫妻性爱视频| 欧美一级淫片007| 秋霞国产精品| 老太脱裤让老头玩ⅹxxxx| 国产精品国产三级国产aⅴ中文| 色综合免费视频|