rabbitmq使用dead letter机制来进行retry

系统 1891 0

首先建立 工作exchange和工作queue,指定工作队列的x-dead-letter-exchange到重试exchenge

    
      var 
    
    
      workQueueArgs = 
    
    
      new 
    
    
      Dictionary
    
    
      <
    
    
      string
    
    
      , 
    
    
      object
    
    
      > {

    { 
    
    
      "x-dead-letter-exchange"
    
    
      , RETRY_EXCHANGE },

};



channel.ExchangeDeclare(WORK_EXCHANGE, 
    
    
      "direct"
    
    
      );

channel.QueueDeclare(WORK_QUEUE, 
    
    
      true
    
    
      , 
    
    
      false
    
    
      , 
    
    
      false
    
    
      , workQueueArgs);

channel.QueueBind(WORK_QUEUE, WORK_EXCHANGE, 
    
    
      ""
    
    
      , 
    
    
      null
    
    
      );
    
  
    
    
  

之后建立重试exchange和重试queue

    
      var 
    
    
      queueArgs = 
    
    
      new 
    
    
      Dictionary
    
    
      <
    
    
      string
    
    
      , 
    
    
      object
    
    
      > {

    { 
    
    
      "x-dead-letter-exchange"
    
    
      , WORK_EXCHANGE },

    { 
    
    
      "x-message-ttl"
    
    
      , RETRY_DELAY }

};



channel.ExchangeDeclare(RETRY_EXCHANGE, 
    
    
      "direct"
    
    
      );

channel.QueueDeclare(RETRY_QUEUE, 
    
    
      true
    
    
      , 
    
    
      false
    
    
      , 
    
    
      false
    
    
      , queueArgs);

channel.QueueBind(RETRY_QUEUE, RETRY_EXCHANGE, 
    
    
      ""
    
    
      , 
    
    
      null
    
    
      );
    
  

重试队列需要2个属性,一个是 x-dead-letter-exchange,指向到工作exchange

一个是过期时间(这里等于是多少秒后重试)

 

监听工作队列,处理消息

    
      QueueingBasicConsumer 
    
    
      consumer = 
    
    
      new 
    
    
      QueueingBasicConsumer
    
    
      (channel);

channel.BasicConsume(WORK_QUEUE, 
    
    
      false
    
    
      , consumer);




    
    
      while 
    
    
      (
    
    
      true
    
    
      )

{

    
    
    
      BasicDeliverEventArgs 
    
    
      e = (
    
    
      BasicDeliverEventArgs
    
    
      )consumer.Queue.Dequeue();

    
    
    
      var 
    
    
      message = 
    
    
      Encoding
    
    
      .UTF8.GetString(e.Body);

    
    
    
      try

    
    
    
      {

        
    
    
      //throw new Exception("");

        
    
    
      channel.BasicAck(e.DeliveryTag, 
    
    
      false
    
    
      );

    }

    
    
    
      catch

    
    
    
      {

        channel.BasicNack(e.DeliveryTag, 
    
    
      false
    
    
      , 
    
    
      false
    
    
      );

    }

}
    
  

处理成功调用ack,处理不成功调用nack,

调用nack后,会根据工作队列的x-dead-letter-exchange自动把消息发到重试队列

重试队列等几秒(x-message-ttl)后,就认为是自动失败了,又会根据重试队列的x-dead-letter-exchange发送回工作队列

rabbitmq使用dead letter机制来进行retry


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论