如何基于RabbitMQ实现优先级队列
来源:互联网 发布:linux中打开一个文件 编辑:程序博客网 时间:2024/05/08 12:33
概述
由于种种原因,RabbitMQ到目前为止,官方还没有实现优先级队列,只实现了Consumer的优先级处理。
但是,迫于种种原因,应用层面上又需要优先级队列,因此需求来了:如何为RabbitMQ加入优先级队列特性。
查询资料后,得知RabbitMQ虽然官方没有支持此特性,但是社区已经有相关优先级队列插件了,并且这个插件被列在RabbitMQ官方网站中了。
地址如下:http://www.rabbitmq.com/community-plugins.html
插件安装
不要立刻下载这个url中的那个链接,要先根据你想要更新目标的rabbitmq版本再去另外一个地方下载相应插件,如:
会列出两大版本的插件目录(选择对应目录进入下载,否则会报错...):
%26nbsp;
插件如何安装?
进入rabbitmq安装目录,进入plugins目录,将上面这个ez文件拷贝到plugins目录中,然后运行命令来enable这个插件
centos下,默认路径在:/usr/lib/rabbitmq/lib/rabbitmq_server-3.3.4/plugins(版本号可能会变化)
windows下,默认路径在:C:\Program Files\RabbitMQ Server\rabbitmq_server-3.3.4\plugins(版本号可能会变化)
把ez文件拷贝过去,然后运行列举插件列表命令:
找到这个优先级队列插件名为:rabbitmq_priority_queue
执行:rabbitmq-plugins enable rabbitmq_priority_queue
ok,重新启动rabbitmq-server服务。
这样,server端的配置算完成了。
%26nbsp;
C#代码端需要作出的更改
下面看看客户端类库的编写:
我们先要定义优先级枚举,继承自byte,因为RabbitMQ的C#客户端优先级是用byte来传递的:
先定义3个级别的优先级:低、中、高(其实可以定义很多级别,只是为了简化,因此只定义了3个级别)
有2个地方需要改动:
- 申明队列时需要加入自定义的属性
- 发送消息到rabbitmq时,设置自定义属性
%26nbsp;
internal static IDictionary%26lt;string, object%26gt; QueueArguments { get { IDictionary%26lt;string, object%26gt; arguments=new Dictionary%26lt;string, object%26gt;(); arguments["x-max-priority"] = 10;//定义队列优先级为10个级别 return arguments; } }
%26nbsp;%26nbsp;
channel.QueueDeclare("queueName", true, false, false, QueueArguments);//QueueArguments就是上面定义的这个dictionary
%26nbsp;%26nbsp;
var headers = channel.CreateBasicProperties();headers.Priority = (byte)msg.Priority;//在这里把继承自byte的枚举转换成bytechannel.BasicPublish("exchange", "route", headers, SerializerUtility.Serialize2Bytes(msg));
%26nbsp;%26nbsp;
%26nbsp;其他注意的地方
在装了优先级队列插件的rabbitmq-server实例中,所有的Durable队列必须用如上的方式,设置x-max-priority属性,否则rabbitmq-server服务会crash
%26nbsp;
- 如何基于RabbitMQ实现优先级队列
- 如何基于RabbitMQ实现优先级队列
- 如何基于RabbitMQ实现优先级队列
- 如何基于RabbitMQ实现优先级队列
- 如何基于RabbitMQ实现优先级队列
- 如何基于RabbitMQ实现优先级队列
- rabbitmq结合spring实现消息队列优先级
- 基于 rabbitmq 实现延迟队列
- 基于 rabbitmq 实现延迟队列
- RabbitMQ之队列优先级
- RabbitMQ如何实现延迟队列?
- RabbitMQ如何实现迟队列
- 基于PHP使用rabbitmq实现消息队列
- RabbitMQ3.5.0版本之后关于RabbitMQ实现队列优先级
- (九) RabbitMQ3.5.0版本之后关于RabbitMQ实现队列优先级
- 基于大顶堆实现的最大优先级队列
- 基于邻接表和优先级队列的Dijkstra算法实现
- java基于有序链表的优先级队列实现
- poj-3067
- 如何基于RabbitMQ实现优先级队列
- 如何基于RabbitMQ实现优先级队列
- 11、congtiki系统开发-coap功能测试-知识储备
- 如何基于RabbitMQ实现优先级队列
- 如何基于RabbitMQ实现优先级队列
- 关于c#文件流与二进制的读入写出(一)
- 如何基于RabbitMQ实现优先级队列
- 如何基于RabbitMQ实现优先级队列
- 混沌分形之谢尔宾斯基(Sierpinski)
- 混沌分形之谢尔宾斯基(Sierpinski)
- 混沌分形之谢尔宾斯基(Sierpinski)
- 混沌分形之谢尔宾斯基(Sierpinski)
- 混沌分形之谢尔宾斯基(Sierpinski)