其他分享
首页 > 其他分享> > .Net Core&RabbitMQ优先级队列

.Net Core&RabbitMQ优先级队列

作者:互联网

优先级队列

消息除了有生命周期长短,也有紧急与非紧急之分,承载了具有优先级消息的队列则为优先级队列。


队列优先级设置

为消息设置优先级前,队列需要先具备优先级的能力,队列设置参数时,可添加x-max-priority来设置队列中消息能够达到的最高优先级(255封顶但推荐设置在1-10之间)。

var queueName = "priority_queue";
var arguments = new Dictionary<string, object>
{
    { "x-max-priority", 3 }
};
channel.QueueDeclare(queue: queueName, durable: false, exclusive: false, autoDelete: false, arguments: arguments);

Web管理页面中可以看到该队列打上了Pri的Tag。

图片


消息优先级设置

为消息设置优先级,以此在队列中消息很多时,优先级高的消息可以被优先消费。发送消息时添加参数,设置Priority属性。

for (int i = 0; i < 10; i++)
{
    var message = "第" + (i + 1) + "条消息";
    byte priority = 0;
    switch (i)
    {
        case < 3:
            message += "-info";
            priority = 1;
            break;
        case < 6:
            message += "-warn";
            priority = 2;
            break;
        default:
            message += "-error";
            priority = 3;
            break;
    }

    var body = Encoding.UTF8.GetBytes(message);
    var basicProperties = channel.CreateBasicProperties();
    basicProperties.Priority = priority;
    channel.BasicPublish(exchange: "", routingKey: queueName, basicProperties: basicProperties, body: body);
    Console.WriteLine("消息内容发送完毕:" + message);
}

如上设置消息优先级随时间逐段增高,运行代码,优先级高的消息后进入队列,消费者优先获取高优先级消息。
图片

注:当消费者消费消息的速度快过生产者发送消息的速度并且队列中没有消息堆积下,优先级设置则失去意义,消息到达队列就被消费了。


2022-09-05,望技术有成后能回来看见自己的脚步

标签:Core,优先级,队列,RabbitMQ,priority,消息,设置,Net,message
来源: https://www.cnblogs.com/CKExp/p/16656155.html