.Net RabbitMQ实战指南——进阶(一)

using (var channel = connection.CreateModel())
{
//设置备胎交换器参数
var arguments = new Dictionary<string, object>();
arguments.Add(“alternate-exchange”,“myAe”);
channel.ExchangeDeclare(“normalExchange”, “direct”,true,false, arguments);
channel.ExchangeDeclare(“myAe”, “fanout”, true, false);
channel.QueueDeclare(“nromalQueue”,true,false,false);
channel.QueueBind(“nromalQueue”, “normalExchange”, “normalKey”);
channel.QueueDeclare(“unroutedQueue”, true, false, false);
channel.QueueBind(“unroutedQueue”, “myAe”,“ae”);

                var properties = channel.CreateBasicProperties();
                properties.DeliveryMode = 2;
                string message = "RabbitMQ Test"; //传递的消息内容
                channel.BasicPublish("normalExchange", "normalKey", properties, Encoding.UTF8.GetBytes(message)); //生产消息
                channel.BasicPublish("normalExchange", "un-routkey", properties, Encoding.UTF8.GetBytes(message)); //生产消息

                Console.WriteLine($"Send:{message}");
            }

复制代码
代码中声明了两个交换器normalExchange和myAe,分别绑定了normalQueue和unroutedQueue这两个队列,同时将myAe设置为normalExchange的备份交换器。myAe的交换器类型为fanout。同时生成两条消息,其中“un-routkey”并没有定义对应路由。

运行效果:

切换到queues视图,可以看到两个队列分别有一条需要消费的消息。

备份交换器与普通的交换器没有太大的区别,为了方便使用,建议设置为fanout类型

过期时间(TTL)
TTL,Time to Live的简称,即过期时间。RabbitMQ可以对队列和消息设置TTL。

设置队列的TTL
channel.QueueDeclare方法中的x-expires参数可以设置队列被自动删除前处于未使用状态的时间。未使用是指队列上没有任何的消费者,队列也没有被重新声明过,并且其间内也未调用过Basic.Get命令。

var arguments = new Dictionary<string, object>();
arguments.Add(“x-expires”, 10000); //单位毫秒
channel.QueueDeclare(arguments: arguments);
RabbitMQ重启后,持久化的队列的过期时间会被重新计算。

设置消息的TTL
消息的过期时间有两种设置方式。第一种是通过队列属性设置,队列中所有消息都有相同的过期时间。第二种方法是对消息本身进行设置。

如果两种方法一起使用,则消息的TTL以两者之间较小的那个数值为准。消息在队列中的生存时间一旦超过设置的TTL值,就会变成“死信”(Dead Message)

通过队列属性设置消息TTL的方法是在channel.QueueDeclare方法中加入x-message-ttl参数实现的,这个参数的单位是毫秒。

arguments.Add(“x-message-ttl”, 6000); //单位毫秒
channel.QueueDeclare(arguments: arguments);
对消息本身进行过期时间设置前面代码有涉及过,是通过BasicPublish方法的basicProperties参数指定。

复制代码
var properties = channel.CreateBasicProperties();
properties.DeliveryMode = 1;
properties.Priority = 2;
properties.Expiration = “6000”;
var message = “RabbitMQ Test”; //传递的消息内容
channel.BasicPublish("", “stacking”, properties, Encoding.UTF8.GetBytes(message)); //生产消息
复制代码
死信队列
DLX,全称为Dead-Letter-Exchange,即死信交换器。当一个消息在队列中变成死信(dead message),它就会被重新被发送到DLX(死信交换器),绑定DLX的队列就称之为死信队列。

通过在channel.QueueDeclare方法中设置x-dead-letter-exchange参数来为这个队列添加DLX.

示例代码:

复制代码
var arguments = new Dictionary<string, object>();
arguments.Add(“x-expires”, 10000); //单位毫秒
arguments.Add(“x-message-ttl”, 6000); //单位毫秒
channel.QueueDeclare(arguments: arguments);

channel.ExchangeDeclare(“dlx_exchange”, “direct”);
var argumentsDlx = new Dictionary<string, object>();
argumentsDlx.Add(“x-dead-letter-exchange”, “dlx_exchange”);
argumentsDlx.Add(“x-dead-letter-routing-key”, “dlx-routing-key”); //为DLX指定路由键,如果没有特殊指定,则使用原队列的路由键
channel.QueueDeclare(“dlx_queue”,false,false,false,argumentsDlx);
USB Microphone https://www.soft-voice.com/
Wooden Speakers https://www.zeshuiplatform.com/
亚马逊测评 www.yisuping.cn
深圳网站建设www.sz886.com

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值