RabbitMQ-PHP(2)Publish/Subscribe之exchange-fanout

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

提示:这里可以添加本文要记录的大概内容:
例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。


提示:以下是本篇文章正文内容,下面案例可供参考

一、Publish/Subscribe?

官方文章链接

font color=#999AAA >示例:pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。
该模式主要讲了exchange交换器fanout这个模式,通过publisher发布信息到exchange,然后exchange把同一个消息发给每一个与之绑定的队列,然后由各自队列的consumer消费.

二、使用步骤

1.发送代码

emit_log.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->exchange_declare('logs', 'fanout', false, false, false);
	
	$data = implode(' ', array_slice($argv, 1));
	if (empty($data)) {
	    $data = "info: Hello World!";
	}
	$msg = new AMQPMessage($data);
	
	$channel->basic_publish($msg, 'logs');
	
	echo ' [x] Sent ', $data, "\n";
	
	$channel->close();
	$connection->close();

2.接收代码

代码如下(示例):

<?php
	
	require_once __DIR__ . '/vendor/autoload.php';
	use PhpAmqpLib\Connection\AMQPStreamConnection;
	
	$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
	$channel = $connection->channel();
	
	$channel->exchange_declare('logs', 'fanout', false, false, false);
	
	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 ($channel->is_open()) {
	    $channel->wait();
	}
	
	$channel->close();
	$connection->close();

3.运行结果:

执行:

php receive_logs.php
php receive_logs.php
php emit_log.php

结果:
在这里插入图片描述
在这里插入图片描述
可以看到,发送一条记录给exchange,两个队列分别对应的两个消费者都接收到了相同的消息.

4.要点解读:

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

该函数设置交换器的参数,exchange的类型在第二个位置设置,目前有四种类型:direct, topic, headers ,fanout.本章用的是fanout,意思是将接收的信息,发送给所有绑定该交换机的队列.

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

在之前我们把空出来,是因为没有自定义exchange,所以这块会自动绑定默认exchange.现在我们在定义了之后就可以填上exchange的名称了

3.list($queue_name, ,) = $channel->queue_declare("");

该函数可以返回rabbit自定义的队列名,例如:amq.gen-JzTY20BRgKO-HjmUJj0wLg.并且队列不是持久化的,用完可直接扔掉;

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

在接收交换机消息之前,需要把exchange和queue绑上,这样才能够收到对应exchange的消息

总结

未完待续

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值