RabbitMQ 简单队列的使用

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

安装依赖

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

模式结构

image.png

生产者

生产者链接到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

使用 rabbitmqctl 工具查看队列

# Linux
sudo rabbitmqctl list_queues
# Windows
rabbitmqctl.bat list_queues
相关文章
相关标签/搜索