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

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

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

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

解決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视频精品免费视频免里 | 国产精品乱码免费一区二区 | 国产福利观看 | 在线视频免费观看a毛片 | 婷婷在线观看网站 | 国产视频毛片 | 日本不卡1| 超级97碰碰碰碰久久久久最新 | 色片免费在线观看 | 久久中文字幕久久久久 | 天天操天天干天天干 | 国产大片91精品免费看3 | 一级毛片全部免费播放 | 国产91免费在线观看 | 国产精品免费一区二区三区 | 性欧美高清come | 国产伦精品一区二区三区免费迷 | 亚洲自拍中文 | 日本-区二区三区免费精品 日本热久久 | 中文字幕欧美日韩va免费视频 | 国产精品免费aⅴ片在线观看 | 国产成人精品视频免费大全 | 色偷偷91久久综合噜噜噜噜 | 99精品视频99 | 亚洲成在人线影视天堂网 | 色综合久久中文色婷婷 | 热久久网站 | 好吊妞人成免费视频观看 | 亚欧乱色精品免费观看 | 天天操综合网 | 一级在线 | 欧洲 | 国产一区二区在线观看免费 | 久久大香伊蕉在人线国产昨爱 | 毛片免费视频播放 | 成年网站视频在线观看 | 99久久国内精品成人免费 | 国产永久地址 | 欧美婷婷 | 日本在线观看不卡免费视频 | 99久久综合精品免费 |