简单队列一般为一个生产者、一个消费者、一个队列的结构。php
# composer.json { "require": { "php-amqplib/php-amqplib": ">=3.0" } }
> composer.phar install
生产者链接到RabbitMQ,发送一条消息,而后退出。json
# 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 的消息,一般须要一直保持运行状态以监听消息。composer
# 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
# Linux sudo rabbitmqctl list_queues
# Windows rabbitmqctl.bat list_queues