简单队列通常为一个生产者、一个消费者、一个队列的结构。
安装依赖
# composer.json
{
"require": {
"php-amqplib/php-amqplib": ">=3.0"
}
}
> composer.phar install
模式结构
生产者
生产者连接到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
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。