RabbitMQ实现延迟任务的另一种方案

网上大部分案例介绍的rabbitmq延迟任务都是利用消息的TTL与死信Exchange的方式,其实rabbitmq提供的插件rabbitmq_delayed_message_exchange可以很好的实现延迟消息的功能,

安装 插件 :

1. 打开rabbitmq 插件网站 https://dl.bintray.com/rabbitmq/community-plugins  
2 . 根据对应的rabbitmq版本找插件,下面以我的rabbitmq 3.7.23 版本为例
$ cd /usr/local/rabbitmq/plugins
$ wget   wget https://github.com/rabbitmq/rabbitmq-delayed-message-exchange/releases/download/v3.8.0/rabbitmq_delayed_message_exchange-3.8.0.ez
$ # 或者打开github下载地址 https://github.com/rabbitmq/rabbitmq-delayed-message-exchange/releases/tag/v3.8.0 找到链接也可以下载
$ unzip rabbitmq_delayed_message_exchange-20171201-3.7.x.zip # 一定要将插件解压到 rabbitmq插件目录
$ rabbitmq-plugins enable rabbitmq_delayed_message_exchange  # 启用安装 延迟插件

使用:
由于在网上找到该插件的使用代码都是基于 java的,通过本人亲测试使用 php的pecl操作。也可以实现相同功能 ,再次推荐使用扩展的形式操作rabbitmq

对于代码来讲,首先对于生产者者核心变化的代码
ex = new \AMQPExchange(channel);
ex->setName(e_name);
ex->setType('x-delayed-message');ex->setArgument('x-delayed-type','direct');
// 发布消息的时候,指定20s 执行
ex->publish(message, k_route,AMQP_NOPARAM,['headers' => ['x-delay' => 20000]]); 有3出注意: 1.类型ex->setType('x-delayed-message'); // 该步骤在 rabbitmq web后台创建 交换机和 队列的时候就可指定,
不需要在代码中体现,正式开发环境中,对于一些交换机,队列的声明和属性绑定,都建议在 rabbbitmq的web后台操作管理。没必要在代码中体现
2.设置参数:$ex->setArgument('x-delayed-type','direct');
3.发布的时候指定延迟执行的时间

对于消费者来说:

ex = new AMQPExchange(channel);
ex->setType('x-delayed-message');ex->setArgument('x-delayed-type','direct');
跟上面一样,需要指定2个参数
1.类型$ex->setType('x-delayed-message');

2.设置参数:$ex->setArgument('x-delayed-type','direct');

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容