大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 hot資訊 解決mq消息丟失問題的方案

解決mq消息丟失問題的方案

更新時間:2022-09-15 09:56:57 來源:動力節點 瀏覽2066次

解決mq消息丟失問題的方案有哪些?動力節點小編來告訴大家。

1.生產者存放消息的過程中丟失消息

解決辦法:

(1)事務機制:(同步方式,不推薦)

對于RabbitMQ消息隊列來說,生產者發送數據之前開啟RabbitMQ的事務機制 channel.txselect,如果消息沒有進隊列,則生產者受到異常報錯,并進行回滾channel.txRollback,然后重試發送消息。如果收到了消息,則可以提交事務channel.txCommit。這是同步操作,會影響性能。

(2)異步機制:

confirm模式來解決同步機制的性能問題。每次生產者發送的消息都會分配一個唯一的id,如果寫入到了RabbitMQ隊列中,則RabbitMQ會回傳一個ack消息,說明這個消息接收成功。如果RabbitMQ沒能處理這個消息,則回調nack接口。說明需要重試發送消息。

也可以自定義超時時間 + 消息 id 來實現超時等待后重試機制。但可能出現的問題是調用ack接口時失敗了,所以會出現消息被發送兩次的問題,這個時候就需要保證消費者消費消息的冪等性。

事務模式和confirm模式的區別:

事務機制是同步的,提交事務后悔被阻塞直到提交事務完成后。

confirm 模式異步接收通知,但可能接收不到通知。需要考慮接收不到通知的場景。

2.消息隊列消息丟失

解決辦法:

(1)創建Queue時,將其設置為持久化

(2)發送消息的時候將消息的deliveryMode設置為2(將消息持久化 1:非持久化,2:持久化)

(3)開啟生產者 confirm`模式,可以重試發送消息。

3.消費者丟失消息

解決辦法:

關閉RabbitMQ的自動ack,每次生產者將消息寫入消息隊列后,就自動回傳一個ack給生產者。

消費者處理完消息再主動ack,告訴消息隊列我處理完了。

4.總結

(1)開啟生產者消息手動確認機制

(2)開啟消息持久化,隊列持久化,交換機持久化(默認開啟)

(3)開啟消費者消息手動確認機制

以上就是關于“解決mq消息丟失問題的方案”介紹,大家如果想了解更多相關知識,可以關注一下動力節點的RabbitMQ教程,里面的課程內容由淺到深,很適合沒有基礎的小伙伴學習,希望對大家能夠有所幫助哦。

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 久久在线精品视频 | 国产在线精品一区免费香蕉 | 欧美国产成人免费观看永久视频 | 欧美日韩中文一区二区三区 | 成人短视频在线免费观看 | 久久精品国产一区 | 成人 亚洲 成人影院 | 久久99精品久久久久久牛牛影视 | 99在线国产 | 狠狠色综合久久婷婷 | 久久青草社区 | 日本精品在线视频 | 久草欧美视频 | 亚洲国产精品二区久久 | 久久爱avwww久久爱 | 奇米影视一区 | 天天弄天天模 | 国产视频一区在线观看 | 色综合欧美亚洲另类久久 | 美女国产在线 | 九九热视频在线观看 | 欧美综合图片区 | 二级毛片全部 | 久久99精品亚洲热综合 | 亚洲综合色视频在线观看 | 日韩视频一区 | 99久久免费精品国产免费 | 久久这里只有精品18 | 四虎影院免费在线 | 欧美线人一区二区三区 | 久久cao| 一级做受视频免费是看美女 | 亚洲精品中文字幕一区在线 | 午夜影院毛片 | 在线亚洲欧洲国产综合444 | 国产成人免费a在线视频色戒 | 亚洲a毛片| 国产欧美一区二区三区免费看 | 日本中文字幕免费 | 日韩精品一区二三区中文 | 成人在线免费观看视频 |