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

聊聊延時消息的六種實現方案

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

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

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

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

實現方案

基于外部存儲實現的方案

這里討論的外部存儲指的是在 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 Tree,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,如此循環。

開源 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 中已經消費的消息數據的空間回收。打個比方,你的 Topic 如果業務上要求支持一個月跨度的延時消息,然后你發了一個延時一個月的消息,那么你這個 Topic 中底層的存儲就會保留整整一個月的消息數據,即使這一個月中99%的正常消息都已經消費了。

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

但是目前,這個方案并沒有對應的實現版本??梢栽趯嶋H使用時,規定只能使用較小時間跨度的延時消息,來減少前兩點缺陷的影響。

另外,因為內存中存的并不是延時消息的全量數據,只是索引,所以可能要積壓上百萬條延時消息才可能對內存造成顯著影響,從這個角度來看,官方暫時沒有完善前兩個問題也可以理解了。

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

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),不會影響到正常消息的空間回收;

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

責任編輯:趙寧寧 來源: 碼猿技術專欄
相關推薦

2022-05-24 11:50:46

延時消息分布式

2025-09-01 08:57:31

2025-05-06 00:00:05

MySQLES協同

2025-05-19 00:02:00

數據脫敏加密算法數據庫

2019-01-17 10:58:52

JS異步編程前端

2025-08-07 02:11:00

2024-11-20 15:24:49

2025-03-17 08:07:11

2024-01-22 08:53:00

策略任務RocketMQ

2023-08-29 13:53:00

前端攔截HashMap

2024-02-26 11:12:33

定時任務線程

2010-03-15 17:12:52

Python字典

2020-10-14 09:00:00

SAST漏洞攻擊

2023-05-10 13:58:13

服務限流系統

2017-06-26 10:35:58

前端JavaScript繼承方式

2022-03-28 20:57:31

私有屬性class屬性和方法

2025-01-21 10:04:40

Java并發阻塞隊列

2018-04-27 15:02:10

2011-02-24 10:56:34

人才

2022-05-12 09:02:50

編程語言PythonJava
點贊
收藏

51CTO技術棧公眾號

国产人与禽zoz0性伦| 在线视频不卡一区二区| 人妻丰满熟妇av无码区| 99热精品久久| 欧美精品一区二区久久久| 午夜精品久久久内射近拍高清| 香蕉视频在线播放| 波多野结衣在线一区| 国产免费一区二区三区香蕉精| 免费在线看黄网址| 成人影视亚洲图片在线| 91精品国产乱| 国产熟女高潮视频| 中文字幕中文字幕在线中高清免费版| www国产精品av| 成人xxxxx色| 中文字幕一区二区三区波野结| 在线观看亚洲| 欧美猛交免费看| 日本一区二区视频在线播放| 国产乱人伦精品一区| 欧美高清激情brazzers| 久久久久久久久久久福利| 日本中文字幕中出在线| 中文字幕一区二区三区不卡| 老牛影视免费一区二区| 国产91免费在线观看| 精品中文av资源站在线观看| 国产精品观看在线亚洲人成网| av资源吧首页| 女人色偷偷aa久久天堂| 日韩在线视频国产| 久久丫精品忘忧草西安产品| 久9re热视频这里只有精品| 日韩一级二级三级| 亚洲精品第三页| 国产亚洲人成a在线v网站 | 一区二区三区视频在线播放| 青青青草原在线| 成人免费观看男女羞羞视频| 99国内精品久久久久久久软件| 91av久久久| 久久精品国产网站| 国产欧美日韩中文| 亚洲在线视频播放| 日本伊人午夜精品| 国产精品一区二区久久精品| 欧美三级网站在线观看| 免费观看久久久4p| 成人国内精品久久久久一区| 国产一区二区女内射| 麻豆精品在线播放| 国产综合久久久久久| 国产一区二区三区在线观看| 久久国产三级精品| 国产精品夜色7777狼人| 91精东传媒理伦片在线观看| 国内精品伊人久久久久av一坑 | 国内精品400部情侣激情| 精品少妇久久久久久888优播| 国产在线欧美| 97色在线观看| 高清乱码免费看污| 日韩精品欧美成人高清一区二区| 国产精品久久久久久久久免费看| 日韩 国产 欧美| 麻豆成人在线观看| 亚洲专区在线视频| 无码精品一区二区三区在线| 久久久久久久一区| 亚洲人成网站在线播放2019| 美女免费久久| 亚洲国产人成综合网站| 国产99久久九九精品无码| 国产一区二区三区朝在线观看| 欧洲精品一区二区| 女人扒开腿免费视频app| 久久久免费毛片| 在线播放国产一区二区三区| 极品久久久久久| 一区二区毛片| 国产精品视频午夜| 免费观看毛片网站| 欧美高清在线一区| av在线免费观看国产| 婷婷综合六月| 日韩女同互慰一区二区| 亚洲熟妇一区二区三区| 99视频精品视频高清免费| 久久久免费电影| 国产成人av免费| 国产91对白在线观看九色| 欧洲精品一区色| 羞羞的视频在线观看| 一本久久综合亚洲鲁鲁五月天| 91在线第一页| 免费一区二区三区视频导航| 久久艳片www.17c.com| 亚洲婷婷综合网| 国产高清无密码一区二区三区| 久久99精品久久久久子伦 | 久久久久久久香蕉网| 99re热视频| www.视频一区| 国产盗摄视频在线观看| 欧美特大特白屁股xxxx| 日韩一卡二卡三卡国产欧美| 国产123在线| 一本一本久久| 91视频婷婷| 永久免费av在线| 欧美性jizz18性欧美| gogo亚洲国模私拍人体| 色婷婷综合网| 日本高清视频一区| 人妻无码中文字幕免费视频蜜桃| 亚洲天堂精品在线观看| 亚洲视频在线a| 奇米777国产一区国产二区| 久久伊人91精品综合网站| 中文字幕av第一页| 久久综合久久99| 国产一级爱c视频| 亚洲高清999| 操91在线视频| 国产精品探花视频| 久久精品夜夜夜夜久久| 久久久噜噜噜www成人网| 荡女精品导航| 久久久久久久97| 精品国产九九九| 亚洲另类春色国产| 爱爱爱爱免费视频| 91日韩在线| 国产一区在线播放| 3d成人动漫在线| 欧美性猛交xxxxxxxx| 卡一卡二卡三在线观看| 日韩精品免费视频人成| 日本一区视频在线| 欧美色片在线观看| 在线成人一区二区| 曰批又黄又爽免费视频| 国产精品久久久久久一区二区三区| 日本男人操女人| 欧美日韩国产在线观看网站| 国产精品劲爆视频| 成年人视频免费在线观看| 欧美在线三级电影| 99久久99久久精品免费看小说.| 日本免费新一区视频| 视频一区三区| 欧美激情啪啪| 久久99精品国产99久久6尤物| 国产成人三级在线播放| 亚洲一区二区三区影院| 特级西西人体4444xxxx| 久久国产一二区| 性欧美精品一区二区三区在线播放| 日韩在线你懂得| 欧美精品在线播放| 刘玥91精选国产在线观看| 精品久久久久久久大神国产| b站大片免费直播| 日本午夜一本久久久综合| 一区视频二区视频| 亚洲综合网狠久久| 欧美在线视频观看| 69视频在线| 日韩欧美成人午夜| 国产午夜精品久久久久| 国产精品免费网站在线观看| 久久综合在线观看| 激情久久久久久| 日本一区网站| 亚洲精品国产九九九| 91av中文字幕| 免费黄网站在线播放| 欧美成人bangbros| 国产一区二区视频免费| 亚洲美腿欧美偷拍| 国产伦精品一区二区三区妓女| 麻豆精品精品国产自在97香蕉 | 男女精品网站| 黄色一级片av| 校园春色另类视频| 91亚洲精品在线观看| 热三久草你在线| 久久精品99久久香蕉国产色戒| 女人18毛片水真多18精品| 欧美午夜精品一区二区三区 | 日本欧美在线视频免费观看| 精品国产伦一区二区三区观看体验 | 在线看女人毛片| 亚洲欧美视频在线| 性做久久久久久久久久| 精品视频1区2区3区| 成年人免费看毛片| 中文字幕一区二区三区视频| av直播在线观看| 国产成人综合在线观看| 日本www.色| 亚洲区一区二| 韩国黄色一级大片| 青草国产精品| 久久久一本精品99久久精品66| 96sao精品免费视频观看| 琪琪第一精品导航| 在线观看免费视频你懂的| 亚洲最新在线视频| 三级视频在线| 精品国产区一区| 性色av蜜臀av| 7777女厕盗摄久久久| 探花国产精品一区二区| 日韩欧美有码在线| 免费看日韩毛片| 亚洲影视资源网| 全程偷拍露脸中年夫妇| 国产精品伦一区二区三级视频| 97人妻精品一区二区免费| av一二三不卡影片| 黑人无套内谢中国美女| 久久99久久99小草精品免视看| 欧美xxxxx在线视频| 99热这里只有成人精品国产| 男人添女荫道口女人有什么感觉| 99久久精品费精品国产风间由美| 视频三区二区一区| 狠狠色丁香婷婷综合影院| 久久草.com| 欧美一区二区三区红桃小说| 国产精品一区二区三区不卡| 成人高潮a毛片免费观看网站| 91成人免费观看| 欧美h版在线观看| 亚洲影院色在线观看免费| 伊人久久综合网另类网站| 成人黄色生活片| 欧美视频精品| 成人免费福利在线| 中文字幕成人| 亚洲综合在线中文字幕| 亚洲精品a区| 国产日韩三区| 欧美男人操女人视频| 久久综合福利| 国产成人短视频在线观看| 亚洲国产一区二区在线| 国产精品伦理久久久久久| 在线视频不卡一区二区| 91九色精品国产一区二区| 中国 免费 av| 好看的日韩av电影| 337p粉嫩大胆噜噜噜鲁| 久久三级视频| 在线观看国产福利| 国产成人精品一区二区三区四区| 国产国语老龄妇女a片| 9l国产精品久久久久麻豆| 女人又爽又黄免费女仆| 国产精品麻豆久久久| 91视频免费在线看| 精品久久久国产精品999| 激情五月婷婷网| 51久久夜色精品国产麻豆| 丰满人妻一区二区| 亚洲女同精品视频| 免费人成在线观看播放视频| 欧美激情精品久久久久久黑人| 中文在线а√天堂| 国产精品亚洲一区二区三区| 亚洲国产视频二区| 欧洲精品亚洲精品| 综合激情视频| 超碰网在线观看| 精久久久久久久久久久| 理论片大全免费理伦片| 欧美一区二区三区久久| 成人激情视频网| 日韩视频1区| 欧美日本韩国一区二区三区| 99久久夜色精品国产亚洲96| 欧美一区二区激情| 视频一区二区国产| 无人码人妻一区二区三区免费| 成人a区在线观看| 国产探花视频在线播放| 亚洲一级二级在线| 在线免费看av片| 亚洲国产欧美一区| 黄色在线视频网站| 欧美一级电影久久| 国产精品一区二区精品视频观看| 久久大香伊蕉在人线观看热2| 国产精品久久观看| 爱福利视频一区二区| 国产美女一区二区| 亚洲av熟女国产一区二区性色| 亚洲男人电影天堂| 99re热视频| 日韩成人久久久| 伊人电影在线观看| 国产精品嫩草影院一区二区| 欧美人妖视频| 国产免费裸体视频| 精品伊人久久久久7777人| 亚洲av综合一区二区| 亚洲一区二区不卡免费| 一区不卡在线观看| 亚洲欧美一区二区三区久久| 国产精品偷拍| 亚洲最大的av网站| 色乱码一区二区三区网站| 久久精品免费一区二区| 国产成人精品免费一区二区| 91麻豆精品久久毛片一级| 色综合天天综合网天天狠天天 | 影院在线观看全集免费观看| 国产精品揄拍500视频| 亚洲素人在线| 国产精品333| www.日韩在线| 91精品国产高潮对白| 日韩视频在线观看一区二区| 欧美激情午夜| 国产欧美日韩综合精品| 欧美一级本道电影免费专区| 日本在线视频www| 久久亚洲私人国产精品va媚药| 国产无遮挡又黄又爽在线观看| 欧美一区二区黄| 菠萝菠萝蜜在线视频免费观看| 成人欧美一区二区三区在线| 欧美国产偷国产精品三区| 亚洲视频一二三四| 中文字幕欧美一区| 一区二区三区精彩视频| 日韩在线中文视频| 福利一区二区三区视频在线观看| 亚洲国产精品一区在线观看不卡| 蜜臀av国产精品久久久久| 丁香激情五月少妇| 欧美人与禽zozo性伦| 麻豆传媒视频在线观看| 91亚洲精品在线观看| 欧美日韩第一区| 色悠悠在线视频| 精品久久久久久久大神国产| 美州a亚洲一视本频v色道| 国产精品爽爽爽爽爽爽在线观看| 欧美激情偷拍自拍| 国产又粗又猛大又黄又爽| 亚洲在线视频网站| 色一情一乱一乱一区91av| 欧美亚洲一级片| 国产伦精品一区二区三区视频| 五月天亚洲视频| 亚洲欧美aⅴ...| 刘玥91精选国产在线观看| 97在线视频精品| 国产尤物久久久| 国产高清av片| 午夜在线电影亚洲一区| 每日更新av在线播放| 成人黄色免费网站在线观看| 国产尤物精品| 国产精品天天干| 777午夜精品免费视频| av在线小说| 亚洲免费视频一区| 国产一区二区精品在线观看| 成人精品在线看| 少妇激情综合网| 国产美女撒尿一区二区| 黄色片在线免费| 一区二区三区四区蜜桃| 黄色软件在线| 97超碰人人看人人| 久久久久91| 极品盗摄国产盗摄合集| 国产视频在线观看一区二区| 亚洲一区二区三区久久久| 亚洲人精品午夜射精日韩| 中文字幕va一区二区三区| 丰满大乳国产精品| 国产精品免费福利| 一区二区亚洲| 大吊一区二区三区| 亚洲福利视频网| 亚洲精品tv| 波多野结衣家庭教师视频| 亚洲免费观看高清完整版在线观看 | 欧美亚洲黄色| 无码精品a∨在线观看中文| 亚洲人成亚洲人成在线观看图片 | 久久这里只有精品一区二区| 性生生活大片免费看视频| 欧美性猛交xxxx乱大交蜜桃| 99福利在线|