ank/queue

redis MessageQueue

1.0.5 2020-01-04 16:55 UTC

This package is auto-updated.

Last update: 2025-01-13 01:16:00 UTC


README

redis rabbitmq实现的消息队列
具体使用方法请看目录下面的示例文件

redis使用方法

use ank\queue\RedisQueue;
//包含自动加载类
$loader = require __DIR__ . '/vendor/autoload.php';

$queue = new RedisQueue([
    'host' => '127.0.0.1',
    'port' => 6379,
], 'default' /*项目名字*/);
// 发送一个消息
$queue->sendMessage('order', 'a message');
// 取出一条信息
$message = $queue->getMessage('order');
var_dump($message);
// 阻塞获取消息
$queue->receiveMessage('order', function ($message, $obj) {
    $body = $message->getBody();
    echo $body;
    //...业务处理
    // 确认消费并删除消息,如果不执行下面则此条消息会被标识为已经接收,但并不会删除
    $obj->acknowledge($message);
    //$obj->reject($message);
});

rabbitmq使用方法

$conf = [
    'host'     => '127.0.0.1',
    'port'     => '5672',
    'login'    => 'guest',
    'password' => 'guest',
    'vhost'    => '/',
];
$obj = new RabbitMQQueue($conf, 'default' /*项目名字*/);

//发送消息到order队列
echo $obj->sendMessage('order', time());

//从队列取出一个消息
$msg = $obj->getMessage('order');
echo $msg;

//删除队列
$obj->deleteQueue('order');
//清除队列中的消息
$obj->clearQueue('order');

// 阻塞回调消息处理
// //接收消息并进行处理的回调方法,回调示例
// public function processMessage($envelope, $queue)
// {
//     //取消息内容
//     $msg = $envelope->getBody();
//     echo $msg . "\n"; //处理消息
//     //显式确认,队列收到消费者显式确认后,会删除该消息
//     $queue->ack($envelope->getDeliveryTag());
// }
//这里直接传啦匿名函数
$obj->receiveMessage('order', function ($envelope, $queue) {
    //取消息内容
    $msg = $envelope->getBody();
    echo $msg . "\n"; //处理消息
    //显式确认,队列收到消费者显式确认后,会删除该消息
    $queue->ack($envelope->getDeliveryTag());
});