美文网首页
rabbit实现延迟任务

rabbit实现延迟任务

作者: 撸代码不如撸猫咪 | 来源:发表于2017-08-20 15:56 被阅读192次

今天和大家分享一个简单的rabbit实现延迟任务的方法,rabbit实现延迟队列有两种方式,一种是队列或者消息的TTL(Time To Live),另一种是rabbit的rabbitmq-delayed-message-exchange插件,今天我和大家分享下TTL的使用方法。

rabbit有Per-Queue Message TTL和Per-Message TTL两种设置超时的方式,分别指针对消息和队列的,给消息添加过期时间相对比较灵活,这样不用每一种过期时间都去建立一个队列去监听,给消息设置过期时间方法

$msg = new AMQPMessage('hello expiration!');
$msg->set("expiration","5000");    //关键一点:超时时间必须设置成字符串,否则不会生效!单位是ms

好了这会儿大家会想超时之后的处理在哪写呢,总有个超时的回调或者什么吧,rabbit可以给队列设置一个x-dead-letter-exchange,Dead letter routing key,意思是消息超时后的转发队列。

$channel->queue_declare("waitSendQueue",false,false,false,false,false,new AMQPTable(array
("x-dead-letter-exchange"=>"expireExchange")));     

waitSendQueue上的消息如果超时了会转发给expireExchange,那我只要去监听expireExchange上的消息,拿到消息去处理业务,就完成了我们的延迟任务,那么接下来上代码.。
客户端:

/**
 * Created by PhpStorm.
 * User: qyc
 * Date: 2017/8/14
 * Time: 下午2:18
 */

require_once dirname(__DIR__) . '/vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;
use PhpAmqpLib\Wire\AMQPTable;
$con = new AMQPStreamConnection('localhost', 5672, "guest", "guest");

$channel = $con->channel();
//定义等待exchange
$channel->exchange_declare('waitSendExchange', 'fanout', false, false, false);
//定义过期exchange
$channel->exchange_declare('expireExchange', 'fanout', false, false, false);
//定义过期queue
$channel->queue_declare("expireQueue",false,false,false,false,false);
//定义等待queue
$channel->queue_declare("waitSendQueue",false,false,false,false,false,new AMQPTable(array
("x-dead-letter-exchange"=>"expireExchange")));
$channel->queue_bind("waitSendQueue","waitSendExchange");
$channel->queue_bind("expireQueue","expireExchange");

$msg = new AMQPMessage('hello expiration!');
/*
 * 设置超时时间
 */
$msg->set("expiration","5000");

/**
 * 向等待exchage发布消息
 */
$channel->basic_publish($msg, 'waitSendExchange');

echo 'send1:' . date('Y-m-d H:i:s') . "\n";

$channel->close();
$con->close();

服务端

/**
 * Created by PhpStorm.
 * User: qyc
 * Date: 2017/8/14
 * Time: 下午2:30
 */

require_once dirname(__DIR__) . '/vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Wire\AMQPTable;

$con  = new AMQPStreamConnection("localhost",5672,"guest","guest");
$channel = $con->channel();

$channel = $con->channel();
//定义等待exchange
$channel->exchange_declare('waitSendExchange', 'fanout', false, false, false);
//定义过期exchange
$channel->exchange_declare('expireExchange', 'fanout', false, false, false);
//定义过期queue
$channel->queue_declare("expireQueue",false,false,false,false,false);
//定义等待queue
$channel->queue_declare("waitSendQueue",false,false,false,false,false,new AMQPTable(array
("x-dead-letter-exchange"=>"expireExchange")));
$channel->queue_bind("waitSendQueue","waitSendExchange");
$channel->queue_bind("expireQueue","expireExchange");

$callback = function ($msg){
    echo "\n".' [x] ', $msg->body, "\n";
    echo "receive2:".date("Y-m-d H:i:s")."\n";
};
/**
 * 订阅超时queue
 */
$channel->basic_consume("expireQueue","",false,true,false,false,$callback);

while (count($channel->callbacks)){
    $channel->wait();
}

$channel->close();
$connection->close();

结果:
发送:


image.png

接受:

image.png

相关文章

  • rabbit实现延迟任务

    今天和大家分享一个简单的rabbit实现延迟任务的方法,rabbit实现延迟队列有两种方式,一种是队列或者消息的T...

  • RabbitMq延迟、重试队列及Spring Boot的黑科技

    背景 Spring Boot对于Rabbit有了AutoConfig的功能,但是延迟队列及失败重试却没有很好的实现...

  • 10.延迟队列

    文章参考:Rabbit实战指南 延迟队列 延迟队列存储的对象是对应的延迟消息,所谓“延迟消息”是指当消息被发送以后...

  • 使用RabbitMQ实现延迟任务

    使用RabbitMQ实现延迟任务 1.问题提出 场景一:对指定url进行post回调,会按照间隔1,2,4,8,1...

  • 用GCD实现延迟执行任务

    用GCD实现延迟执行任务 // [self performSelector:@selector(doSometh...

  • 30.ScheduledThreadPoolExecutor

    ScheduledThreadPoolExecutor实现了按时间调度来执行任务 1.延迟执行任务 public ...

  • 几种延迟任务的实现思路

    前言 最近有个延迟执行的任务需求,比如发了一个定时红包,服务器不能相信客户端的一切,所以就得做时间的同步,但是PH...

  • 延迟性任务实现解析

    背景 很多人在面试的时候可能都碰到过这样的一个面试题:设计一个秒杀系统,30分钟没付款就自动关闭交易,这里我们主要...

  • Laravel源码分析 - Redis延迟队列(一)

    延迟队列,首先它是一个队列。然后其任务可以延迟被执行。实现队列,以及延迟队列的方式有很多种,基于Redis的方式也...

  • 延迟任务

    [研究背景] ?: 下单之后如果三十分钟之内没有付款就自动取消订单。?: 定时任务的调度, 当天某些需要处理...

网友评论

      本文标题:rabbit实现延迟任务

      本文链接:https://www.haomeiwen.com/subject/qiufdxtx.html