网上大部分案例介绍的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
对于代码来讲,首先对于生产者者核心变化的代码
channel);
e_name);
ex->setArgument('x-delayed-type','direct');
// 发布消息的时候,指定20s 执行
message, ex->setType('x-delayed-message'); // 该步骤在 rabbitmq web后台创建 交换机和 队列的时候就可指定,
不需要在代码中体现,正式开发环境中,对于一些交换机,队列的声明和属性绑定,都建议在 rabbbitmq的web后台操作管理。没必要在代码中体现
2.设置参数:$ex->setArgument('x-delayed-type','direct');
3.发布的时候指定延迟执行的时间
对于消费者来说:
channel);
ex->setArgument('x-delayed-type','direct');
跟上面一样,需要指定2个参数
1.类型$ex->setType('x-delayed-message');
2.设置参数:$ex->setArgument('x-delayed-type','direct');