1

简单队列通常为一个生产者、一个消费者、一个队列的结构。

安装依赖

# composer.json
{
    "require": {
        "php-amqplib/php-amqplib": ">=3.0"
    }
}
> composer.phar install

模式结构

image.png

生产者

生产者连接到RabbitMQ,发送一条消息,然后退出。

# send.php

<?php
require_once __DIR__ . '/vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;

// 创建连接
$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');

// 创建通道
$channel = $connection->channel();

// 创建队列,已存在的队列不会重复创建
$channel->queue_declare('hello', false, false, false, false);

$msg = new AMQPMessage('Hello World!');
// 通过默认的交换机发送消息到队列 (消息内容, 默认交换机, 路由键)
$channel->basic_publish($msg, '', 'hello');

echo " [x] Sent 'Hello World!'\n";

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

消费者

消费者监听来自 RabbitMQ 的消息,通常需要一直保持运行状态以监听消息。

# receive.php

<?php
require_once __DIR__ . '/vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPStreamConnection;

// 创建连接
$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');

// 创建通道
$channel = $connection->channel();

// 创建队列,已存在的不会重复创建
$channel->queue_declare('hello', false, false, false, false);

echo " [*] Waiting for messages. To exit press CTRL+C\n";

// 定义消息处理回调函数
$callback = function ($msg) {
    echo ' [x] Received ', $msg->body, "\n";
};

$channel->basic_consume('hello', '', false, true, false, false, $callback);

while ($channel->is_open()) {
    $channel->wait();
}

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

运行

打开一个终端,运行消费者:

php receive.php

打开另一个终端,运行生产者:

php send.php

使用 rabbitmqctl 工具查看队列

# Linux
sudo rabbitmqctl list_queues
# Windows
rabbitmqctl.bat list_queues

小伍
139 声望4 粉丝

引用和评论

0 条评论