五分鐘帶你玩轉rabbitmq(七)怎么保證消息不丟失

      網友投稿 826 2025-04-01

      先來說明一個概念,什么是可靠投遞呢?在RabbitMQ中,一個消息從生產者發送到RabbitMQ服務器,需要經歷這么幾個步驟:

      生產者準備好需要投遞的消息。

      生產者與RabbitMQ服務器建立連接。

      生產者發送消息。

      RabbitMQ服務器接收到消息,并將其路由到指定隊列。

      RabbitMQ服務器發起回調,告知生產者消息發送成功。

      所謂可靠投遞,就是確保消息能夠百分百從生產者發送到服務器。

      隊列存在的以下問題:消息丟失問題?重復消費問題 以下為解決點

      1:隊列持久化硬盤

      丟失的過程就只有在內存發送到磁盤時會丟失消息?如果保存到磁盤后 重啟服務消息不會丟失 但是會影效率

      new Queue("demo_queue", true, false, false, args); 第二個參數為true

      2:手動ack

      告知生產者消息成功/失敗,否則,如果失敗此隊列會保持掛起狀態,他們消息會等待。所以在消費完成之后通知生產者消費是否成功/失敗,ack/nack

      配置文件

      rabbitmq:

      host: 192.168.xx.xx

      port: 5672

      username: root

      password: root

      virtual-host: /

      listener:

      simple:

      acknowledge-mode: manual #手動應答

      prefetch: 1 # 每次只處理一個信息

      publisher-confirms: true #開啟消息確認機制

      五分鐘帶你玩轉rabbitmq(七)怎么保證消息不丟失

      publisher-returns: true #支持消息發送失敗返回隊列

      @RabbitListener(queues = "demo_queue")

      protected void consumerDead(Message message, Channel channel) throws Exception {

      RabbitEnum ackSign = RabbitEnum.ACCEPT;

      try {

      int i = 10 / 0;

      } catch (Exception e) {

      ackSign = RabbitEnum.RETRY;

      throw e;

      } finally {

      // 通過finally塊來保證Ack/Nack會且只會執行一次

      if (ackSign == RabbitEnum.ACCEPT) {

      channel.basicAck(message.getMessageProperties().getDeliveryTag(), false);

      } else if (ackSign == RabbitEnum.RETRY) {

      channel.basicNack(message.getMessageProperties().getDeliveryTag(), false, false);

      }

      }

      }

      3:確認是否發送成功

      判斷消息是否發送到交換機

      @Bean

      public RabbitTemplate rabbitTemplate() {

      Logger logger = LoggerFactory.getLogger(RabbitTemplate.class);

      RabbitTemplate rabbitTemplate = new RabbitTemplate(connectionFactory);

      // 消息發送失敗返回到隊列中, yml需要配置 publisher-returns: true

      rabbitTemplate.setMandatory(true);

      // 發送消息確認, yml需要配置 publisher-confirms: true 消息是否發送的核心配置

      rabbitTemplate.setConfirmCallback(msgSendConfirmCallBack());

      // 消息返回, yml需要配置 publisher-returns: true 消息返回的配置

      rabbitTemplate.setReturnCallback((message, replyCode, replyText, exchange, routingKey) -> {

      String correlationId = message.getMessageProperties().getCorrelationId().toString();

      logger.debug("消息:{} 發送失敗, 應答碼:{} 原因:{} 交換機: {} 路由鍵: {}", correlationId, replyCode, replyText, exchange,

      routingKey);

      });

      return rabbitTemplate;

      }

      /**

      * 確認發送消息是否成功

      *

      * @return

      */

      @Bean

      public MsgSendConfirmCallBack msgSendConfirmCallBack() {

      return new MsgSendConfirmCallBack();

      }

      public class MsgSendConfirmCallBack implements RabbitTemplate.ConfirmCallback {

      /**

      * 回調方法

      * @param correlationData

      * @param ack

      * @param cause

      */

      @Override

      public void confirm(CorrelationData correlationData, boolean ack, String cause) {

      System.out.println("MsgSendConfirmCallBack , 回調id:" + correlationData);

      if (ack) {

      System.out.println("消息發送成功");

      } else {

      //可以將消息寫入本地,使用定時任務重新發送

      System.out.println("消息發送失敗:" + cause + "\n重新發送");

      }

      }

      }

      4:集群化處理

      5:異地容災

      6:發送消息持久化到db中 進行消息的重新發送

      7:消費者消息固話到db中 通過消息id判斷是否重復消費

      參考:https://www.freesion.com/article/1880596463/

      RabbitMQ

      版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。

      版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。

      上一篇:從ERP項目失敗中恢復
      下一篇:excel2003添加背景圖片的教程
      相關文章
      亚洲人成亚洲精品| 亚洲欧洲美洲无码精品VA| 亚洲av无码专区在线播放| 中文字幕亚洲激情| 亚洲欧洲日产国码高潮αv| 亚洲AV第一成肉网| 亚洲精品久久无码| 亚洲精品天堂成人片AV在线播放| 亚洲色精品VR一区区三区| 在线a亚洲老鸭窝天堂av高清| 2020久久精品亚洲热综合一本| 亚洲毛片在线免费观看| 亚洲成a人片在线观看中文!!!| 亚洲欧洲中文日产| 亚洲一区电影在线观看| 亚洲AV无码乱码在线观看代蜜桃 | 久久久亚洲精品蜜桃臀| 国产偷国产偷亚洲清高动态图| 久久久久一级精品亚洲国产成人综合AV区 | 亚洲熟妇色自偷自拍另类| 亚洲毛片基地日韩毛片基地| 精品亚洲麻豆1区2区3区| 亚洲色av性色在线观无码| 久久精品国产亚洲av麻豆小说| 久久亚洲国产成人精品性色| 亚洲视频免费在线播放| 亚洲福利视频网址| 亚洲 暴爽 AV人人爽日日碰| 亚洲午夜无码久久| 精品无码专区亚洲| 亚洲国产精品综合久久网络| 久久综合亚洲色HEZYO国产| 亚洲色偷偷偷鲁综合| 亚洲av综合av一区| 91亚洲国产在人线播放午夜| 亚洲天堂一区二区三区| 在线观看亚洲AV日韩AV| 亚洲国产精品毛片av不卡在线| 久久久久国产成人精品亚洲午夜| 亚洲毛片αv无线播放一区| 亚洲免费视频在线观看|