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

.Net Core&RabbitMQ优先级队列

时间:2022-09-05 06:55:22浏览次数:68  
标签:Core 优先级 队列 RabbitMQ priority 消息 设置 Net message

优先级队列

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


队列优先级设置

为消息设置优先级前,队列需要先具备优先级的能力,队列设置参数时,可添加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
From: https://www.cnblogs.com/CKExp/p/16656155.html

相关文章

  • c# 框架系列 ———— EFCore 模型篇 [一]
    前言简单介绍一下EfCore的模型篇正文内容来源:配置模型配置模型的方式,一种是fluentapi还一种是属性的方式。publicclassBlog{ publicintBlogId{get;set;......
  • Docker容器:利用Kubernetes、Flannel、Cockpit和Atomic构建和部署 pdf
    高清扫描版下载链接:https://pan.baidu.com/s/1bGR-iSE5_jHNvP1QWHKs3g点击这里获取提取码Linux系统或云环境上运行Docker的实用指南!无论是在笔记本上还是在远程云上,Docke......
  • Kubernetes零基础快速入门 pdf
    高清扫描版下载链接:https://pan.baidu.com/s/1ngjbxbqQnSs4K4xd5nzt5Q点击这里获取提取码Kubernetes为容器化的应用提供了资源调度、部署、运行、服务发现、扩容和缩容等......
  • 1.try-except 2. if 0<=score<=1.0 3. print加引号是为什么
    Assignment3.3Writeaprogramtopromptforascorebetween0.0and1.0.Ifthescoreisoutofrange,printanerror.Ifthescoreisbetween0.0and1.0,pri......
  • .Net下的简易Http请求调用(Post与Get)
    http请求调用是开发中经常会用到的功能。在内,调用自有项目的WebApi等形式接口时会用到;在外,调用一些第三方功能接口时,也会用到,因为,这些第三方功能往往是通过http地址的形式......
  • 如何不编写 YAML 管理 Kubernetes 应用?
    Kubernetes将自身边界内的事物都抽象为资源。其中的主要部分,是以Deployment、StatefulSet为代表的workload工作负载控制器,其他各类资源都围绕这些主要的资源工作。这......
  • .Net下的Http请求调用(Post与Get)
    http请求调用是开发中经常会用到的功能。在内,调用自有项目的WebApi等形式接口时会用到;在外,调用一些第三方功能接口时,也会用到,因为,这些第三方功能往往是通过http地址的形式......
  • ASP.NET Core源码,数据结构和算法,
    ASP.NETCore源码:https://github.com/dotnet/aspnetcore#ASP.NETCorehttps://github.com/dotnet/runtime#extend扩展库https://github.com/aspnet/KestrelHttpServer ......
  • 在cmd运行窗口中输入DOS命令netstat,即可查看电脑的tcp连接。
    如何查看tcp连接_百度知道 https://zhidao.baidu.com/question/202977646.html在cmd运行窗口中输入DOS命令netstat,即可查看电脑的tcp连接。具体操作请参照以下步骤。1......
  • 在 .NET / C# 中管理命令行参数
    在.NET/C#中管理命令行参数创建控制台应用程序时,我们经常需要处理通过命令行传递的参数。本文介绍了一种使用命令行解析器nuget包。Photoby奥斯卡·耶尔迪兹......