日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

三分鐘白話RocketMQ系列—— 如何發送消息

來源: 責編: 時間:2023-08-05 11:46:05 4937觀看
導讀我們知道RocketMQ主要分為消息 生產、存儲(消息堆積)、消費 三大塊領域。那接下來,我們白話一下,RocketMQ是如何發送消息的,揭秘消息生產全過程。注意,如果白話中不小心提到相關代碼配置與類名,請參考RocketMQ 4.9.4版本關鍵

我們知道RocketMQ主要分為消息 生產、存儲(消息堆積)、消費 三大塊領域。ZEj28資訊網——每日最新資訊28at.com

那接下來,我們白話一下,RocketMQ是如何發送消息的,揭秘消息生產全過程。ZEj28資訊網——每日最新資訊28at.com

注意,如果白話中不小心提到相關代碼配置與類名,請參考RocketMQ 4.9.4版本ZEj28資訊網——每日最新資訊28at.com

關鍵字摘要

  • 哪些消息類型?
  • 發給誰?
  • 怎么發?
  • 怎么知道發成功了還是失敗了?
  • 發失敗了怎么辦?

Q1: RocketMQ有哪些消息類型?

RocketMQ生產消息時,支持多種「消息類型」:ZEj28資訊網——每日最新資訊28at.com

  • 普通消息:發送普通消息。
SendResult send(final Message msg);
  • 普通有序消息:發送普通有序消息,通過指定「消息篩選器selector」,動態決定發送哪個隊列。
SendResult send(final Message msg, final MessageQueueSelector selector, final Object arg);
  • 嚴格有序消息:發送嚴格有序消息,通過指定隊列,保證嚴格有序。
SendResult send(final Message msg, final MessageQueue mq);
  • 事務消息:實現分布式事務。(屬于分布式事務范疇,區別較大,本文不再展開討論,后面單獨寫一篇針對「事務消息」的分析)

上面列舉的三種send方法,都是以同步發送模式為例。定時/延遲消息從發送方式角度來說,不算一種獨立的消息類型。ZEj28資訊網——每日最新資訊28at.com

Q2:RocketMQ怎么知道一條消息要發送給誰?

一般我們要發送一條消息給RocketMQ,需要創建這樣一個消息體。ZEj28資訊網——每日最新資訊28at.com

Message msg = new Message( "TestTopic", "Hello World".getBytes() );

在這個消息體里面,我們只單純指定了要發送的Topic名字,以及要發送的消息內容。ZEj28資訊網——每日最新資訊28at.com

那么,RocketMQ-client怎么知道這條消息要發送到RocketMQ集群中的哪一個broker上呢?ZEj28資訊網——每日最新資訊28at.com

這里需要了解下RocketMQ中Topic的「路由注冊與發現機制」。ZEj28資訊網——每日最新資訊28at.com

RocketMQ基本架構RocketMQ基本架構ZEj28資訊網——每日最新資訊28at.com

Topic 路由注冊與發現:ZEj28資訊網——每日最新資訊28at.com

  • Broker 每30秒向 NameServer 發送心跳包,里面包含Topic的路由信息,包括主題的讀寫隊列數和操作權限等。NameServer會保存這些路由信息,并記錄最后一次收到 Broker 心跳包的時間(NameServer每10秒根據記錄的時間戳清理已經失聯120秒以上的 Broker)。
  • 生產者每30秒獲取一次主題的路由信息。這意味著消息生產者不會立即知道有新的 Broker 加入或者被移除。

Topic路由信息Topic路由信息ZEj28資訊網——每日最新資訊28at.com

Topic的路由信息,包括了Topic的 隊列queue和broker的映射關系 ,那么如何利用這個Topic的路由信息呢?ZEj28資訊網——每日最新資訊28at.com

我們需要根據前面的不同「消息類型」進行分別討論:ZEj28資訊網——每日最新資訊28at.com

  • 普通消息:默認采用輪詢機制,消息會依次發送到Topic的每個可用的 Broker 的某個隊列queue上,以實現負載均衡。
  • 普通有序消息:根據傳遞的 MessageQueueSelector 和消息體 msg 內容,計算可以投遞的隊列queue,然后發送消息。(可以類比分庫分表中的分表計算寫入的方式)
  • 嚴格有序消息:根據傳遞的 MessageQueue 信息,強制消息發送到對應隊列queue上。(可以類比分庫分表中,強制指定物理表寫入的方式)

根據消息類型獲取到目標隊列queue后,就可以根據Topic路由信息發送消息到指定broker上了。ZEj28資訊網——每日最新資訊28at.com

Q3:怎么發送一條消息?

從發送模式角度來說,RocketMQ有三種「消息發送模式」:ZEj28資訊網——每日最新資訊28at.com

  • 同步發送:調用發送消息方法后,同步阻塞,直到返回SendResult。
SendResult send(final Message msg);
  • 異步發送:調用發送消息方法后,立即返回,發送結果會通過開發者自己注冊的回調函數SendCallback進行處理。
void send(final Message msg, final SendCallback sendCallback);
  • 單向發送:這種方法完全不關心發送后的返回結果。顯然,它具有最大吞吐量,但也存在消息丟失的潛在風險。
void sendOneway(final Message msg);

上面列舉的三種send方法,都是以「普通消息」為例。ZEj28資訊網——每日最新資訊28at.com

「消息類型」 和 「消息發送模式」 是 N*M 的關系,所以聰明的你一定已經想到了,存在9種不同組合(不包括事物消息),RocketMQ也是在接口中定義了9種不同方法。ZEj28資訊網——每日最新資訊28at.com

Q4: 發送后,怎么知道消息發成功了還是失敗了?

前面介紹了三種「消息發送模式」,其中「單向發送」屬于不可靠發送,我們無法知道是否發送成功。ZEj28資訊網——每日最新資訊28at.com

而「同步發送」和「異步發送」都是可靠發送,我們能夠獲取發送狀態,知道是否成功。ZEj28資訊網——每日最新資訊28at.com

在「同步發送」中,我們可以根據SendResult中的sendStatus屬性判斷是否發送成功。ZEj28資訊網——每日最新資訊28at.com

SendResult類屬性SendResult類屬性ZEj28資訊網——每日最新資訊28at.com

在「異步發送」中,我們可以自定義實現SendCallback的onSuccess()方法和onException()方法,來判斷消息是否發送成功。ZEj28資訊網——每日最新資訊28at.com

SendCallback接口定義SendCallback接口定義ZEj28資訊網——每日最新資訊28at.com

Q5: 消息發送失敗了怎么辦?

如果消息發送失敗了,RocketMQ-client默認有重試機制,以確保消息的高可用性。ZEj28資訊網——每日最新資訊28at.com

前面提到,生產者每30秒獲取一次主題的路由信息,所以即使某個 Broker 宕機,消息發送者可能無法立即察覺到它的宕機狀態。ZEj28資訊網——每日最新資訊28at.com

但是,當消息發送者向某個 Broker 發送消息后,如果返回異常,生產者會在接下來的一段時間內(例如5分鐘)避免再次選擇該 Broker 上的隊列來發送消息。這樣做的目的是規避可能發生故障的 Broker。ZEj28資訊網——每日最新資訊28at.com

當然了,用戶也能根據返回的異常,自己定義業務重試、補償機制。ZEj28資訊網——每日最新資訊28at.com

需要注意的是,不同「消息類型」和「消息發送模式」的RocketMQ-client默認重試機制不同。ZEj28資訊網——每日最新資訊28at.com

消息類型:ZEj28資訊網——每日最新資訊28at.com

  • 普通消息:無順序性要求,異常時RocketMQ-client默認重試。
  • 普通有序消息:異常時RocketMQ-client默認不重試,可以用戶自己捕獲異常重試,并發送到其他隊列。
  • 嚴格有序消息:保證嚴格有序,異常時RocketMQ-client默認不重試,可以用戶自己捕獲異常重試。

注意:有序消息異常時RocketMQ-client都是默認不重試ZEj28資訊網——每日最新資訊28at.com

消息發送模式:ZEj28資訊網——每日最新資訊28at.com

  • 同步發送:配置retryTimesWhenSendFailed默認重試次數。
  • 異步發送:配置retryTimesWhenSendAsyncFailed默認重試次數。
  • 單向發送:無重試機制,存在丟失消息的風險。

注意:單向發送模式異常時RocketMQ-client默認不重試ZEj28資訊網——每日最新資訊28at.com

總結

  • 有哪些消息類型:普通消息、有序消息、事務消息
  • 發給誰?:Topic路由信息注冊與發現機制、普通消息輪詢發送、有序消息指定selector或者queue發送
  • 怎么發?:同步發送、異步發送、單向發送
  • 怎么知道發成功了還是失敗了?:同步&異步都能夠獲取發送狀態(可靠發送)、單向發送不可靠
  • 發失敗了怎么辦?: 失敗重試機制

本文鏈接:http://www.www897cc.com/showinfo-26-144-0.html三分鐘白話RocketMQ系列—— 如何發送消息

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 使用Webdriver-manager解決瀏覽器與驅動不匹配所帶來自動化無法執行的問題

下一篇: 從零到英雄:高并發與性能優化的神奇之旅

標簽:
  • 熱門焦點
  • 鴻蒙OS 4.0公測機型公布:甚至連nova6都支持

    華為全新的HarmonyOS 4.0操作系統將于今天下午正式登場,官方在發布會之前也已經正式給出了可升級的機型產品,這意味著這些機型會率先支持升級享用。這次的HarmonyOS 4.0支持
  • 2023 年的 Node.js 生態系統

    隨著技術的不斷演進和創新,Node.js 在 2023 年達到了一個新的高度。Node.js 擁有一個龐大的生態系統,可以幫助開發人員更快地實現復雜的應用。本文就來看看 Node.js 最新的生
  • K8S | Service服務發現

    一、背景在微服務架構中,這里以開發環境「Dev」為基礎來描述,在K8S集群中通常會開放:路由網關、注冊中心、配置中心等相關服務,可以被集群外部訪問;圖片對于測試「Tes」環境或者
  • 谷歌KDD'23工作:如何提升推薦系統Ranking模型訓練穩定性

    谷歌在KDD 2023發表了一篇工作,探索了推薦系統ranking模型的訓練穩定性問題,分析了造成訓練穩定性存在問題的潛在原因,以及現有的一些提升模型穩定性方法的不足,并提出了一種新
  • 一篇文章帶你了解 CSS 屬性選擇器

    屬性選擇器對帶有指定屬性的 HTML 元素設置樣式。可以為擁有指定屬性的 HTML 元素設置樣式,而不僅限于 class 和 id 屬性。一、了解屬性選擇器CSS屬性選擇器提供了一種簡單而
  • 雅柏威士忌多款單品價格大跌,泥煤頂流也不香了?

    來源 | 烈酒商業觀察編 | 肖海林今年以來,威士忌市場開始出現了降溫跡象,越來越多不斷暴漲的網紅威士忌也開始悄然回歸市場理性。近日,LVMH集團旗下蘇格蘭威士忌品牌雅柏(Ardbeg
  • 阿里大調整

    來源:產品劉有媒體報道稱,近期淘寶天貓集團啟動了近年來最大的人力制度改革,涉及員工績效、層級體系等多個核心事項,目前已形成一個初步的“征求意見版”:1、取消P序列
  • 小米汽車電池信息疑似曝光:容量101kWh,支持800V高壓快充

    7月14日消息,今日一名博主在社交媒體發布了一張疑似小米汽車電池信息的照片,顯示該電池包正是寧德時代麒麟電池,容量為101kWh,電壓為726.7V,可以預測小
  • 蘋果公司要求三星和LG Display生產「無邊框」OLED iPhone顯示屏

    據 The Elec 報道,蘋果已要求其供應商為未來的 iPhone 型號開發「無邊框」OLED 顯示面板。蘋果顯然已要求三星和 LG Display 開發新的 OLED 顯示面
Top 主站蜘蛛池模板: 望城县| 儋州市| 青海省| 古丈县| 淮安市| 宜兰市| 长兴县| 岑溪市| 甘谷县| 平乐县| 丹棱县| 福安市| 买车| 襄樊市| 鄯善县| 吉林市| 宁海县| 咸丰县| 固始县| 江永县| 吉隆县| 东乡族自治县| 临安市| 东乌珠穆沁旗| 平遥县| 靖西县| 西丰县| 故城县| 开鲁县| 兴义市| 杨浦区| 桐乡市| 桐梓县| 苏州市| 霍山县| 天气| 拜泉县| 麟游县| 沐川县| 祁东县| 宁远县|