消息队列-RabbitMq(PHP)

本文档介绍了如何在Windows环境下使用Composer安装PHP的RabbitMQ库,并通过一个简单的'Hello World'示例展示了消息发布者(send.php)和消费者(receive.php)的实现,讲解了消息队列的基本工作原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


首先进行安装:


将composer.json文件放在你的项目中

composer.json
{ "require" : { "php-amqplib/php-amqplib" : "2.5.*" } }

将composer进行全局安装之后在项目所在目录执行:composer install即可下载RabbitMq所需库文件。


全部下载之后的目录结构为:
(composer.json文件存放在rabbit(我的项目名称)目录中)


下面是一个简单的“Hello World”测试程序

如图所示:“P”是消息发布者,“C”是消息的消费者,中间红色的是我们的队列,这是一个消息的缓存区

首先构建一个发送消息的文件send.php,即“P”,发布消息

//引用所需文件
require_once __DIR__ . '/vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;
//建立一个连接通道,声明一个可以发送消息的队列hello
$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
$channel = $connection->channel();
$channel->queue_declare('hello', false, false, false, false);

//定义一个消息,消息内容为Hello World!
$msg = new AMQPMessage('Hello World!');
$channel->basic_publish($msg, '', 'hello');

//发送完成后打印消息告诉发布消息的人:发送成功
echo " [x] Sent 'Hello World!'\n";
//关闭连接
$channel->close();
$connection->close();

接着我们需要接受消息,创建一个文件:reveive.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";
};

//在接收消息的时候调用$callback函数
$channel->basic_consume('hello', '', false, true, false, false, $callback);

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

分别运行send.php和receive.php










评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值