博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
rabbitmq使用dead letter机制来进行retry
阅读量:6309 次
发布时间:2019-06-22

本文共 1382 字,大约阅读时间需要 4 分钟。

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

var workQueueArgs = new Dictionary
{ { "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
{ { "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发送回工作队列

转载于:https://www.cnblogs.com/czcz1024/p/4195606.html

你可能感兴趣的文章
ssh
查看>>
订单的子单表格设置颜色
查看>>
Office365 Exchange Hybrid 番外篇 ADFS后端SQL群集(一)
查看>>
9个offer,12家公司,35场面试,从微软到谷歌,应届计算机毕业生的2012求职之路...
查看>>
lvs fullnat部署手册(三)rs内核加载toa篇
查看>>
C++策略模式
查看>>
我的友情链接
查看>>
oracle表分区详解
查看>>
网络编程中常见结构体
查看>>
SSL/TLS原理详解
查看>>
Docker 自定义SSH服务镜像
查看>>
JavaScript强化教程 —— Cocos2d-JS自动JSB绑定规则修改
查看>>
configure: error: in `/root/httpd-2.2.11/srclib/apr': c
查看>>
CentOS7搭建Kubernetes-dashboard管理服务
查看>>
buildroot下查找外部编译器通过ext-toolchain-wrapper调用的参数
查看>>
MySQL Replication 主主配置详细说明
查看>>
Linux的任务调度
查看>>
在Android studio中添加jar包方法如下
查看>>
iframe 在ie下面总是弹出新窗口解决方法
查看>>
分享10款漂亮实用的CSS3按钮
查看>>