[rabbitMQ]六、rabbitMQ队列之发布/订阅模式(fanout)

生产者P将消费发送到X(Exchange交换机),队列RQ6和As8绑定到交换机X。C1对应RQ6,C2对应As8.这样,同一条消息,被C1和C2 同时消费。C1和C2各自拥有对消息全集的消费。比如C1写数据库,C2写搜索引擎,二者写入的数据都完全相同。

生产者(emit_log.php):

<?php

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

$connection = new AMQPStreamConnection('localhost', 5672, 'guest', '123456');
$channel = $connection->channel();

$channel->exchange_declare('logs', 'fanout', false, false, false);

$data = "info: Hello World!";
$msg = new AMQPMessage($data);

$channel->basic_publish($msg, 'logs');

echo " [x] Sent ", $data, "\n";

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

消费者(receive_log.php):

<?php

require_once __DIR__ . '/vendor/autoload.php';

use PhpAmqpLib\Connection\AMQPStreamConnection;

$connection = new AMQPStreamConnection('localhost', 5672, 'guest', '123456');
$channel = $connection->channel();

// 声明一个名称叫做logs的扇形交换器
$channel->exchange_declare('logs', 'fanout', false, false, false);
// 提供队列名称为空字符串时,我们创建了一个具有生成名称的非持久队列
// 方法返回时,$queue_name变量包含一个随机生成的RabbitMQ队列名称
list($queue_name, ,) = $channel->queue_declare("", false, false, true, false);

$channel->queue_bind($queue_name, 'logs');

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

$callback = function ($msg) {
    echo ' [x] ', $msg->body, "\n";
};

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

while (count($channel->callbacks)) {
    $channel->wait();
}

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

注意:
1)这种模式,需要先运行消费者程序,生产者程序执行之后,发送消息。
2)各个消费者可以对消息全集消费,然后消费消息在不同的场景

上一页 下一页

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值