php消息队列rabbitmq

在PHP中使用RabbitMQ,你可以使用php-amqplib库,这是一个纯PHP实现的RabbitMQ客户端。以下是一个简单的生产者和消费者示例。

首先,确保你已经安装了php-amqplib,可以通过Composer进行安装:

bash 复制代码
composer require php-amqplib/php-amqplib

生产者代码示例:

php 复制代码
php
<?php
require_once __DIR__ . '/vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;

// 连接到RabbitMQ服务器
$connection = new AMQPStreamConnection('localhost', 5672, 'user', 'password', 'virtual_host');
$channel = $connection->channel();

// 声明队列
$queue = 'hello';
$channel->queue_declare($queue, false, true, false, false);

// 发送消息
$msg = new AMQPMessage('Hello World!');
$channel->basic_publish($msg, '', $queue);

echo " [x] Sent 'Hello World!'\n";

// 关闭连接
$channel->close();
$connection->close();
?>

消费者代码示例:

php 复制代码
php
<?php
require_once __DIR__ . '/vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPStreamConnection;

// 连接到RabbitMQ服务器
$connection = new AMQPStreamConnection('localhost', 5672, 'user', 'password', 'virtual_host');
$channel = $connection->channel();

// 声明队列
$queue = 'hello';
$channel->queue_declare($queue, false, true, false, false);

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

// 回调函数,当接收到消息时会被调用
$callback = function ($msg) {
    echo " [x] Received ", $msg->body, "\n";
};

// 开始消费消息
$channel->basic_consume($queue, '', false, true, false, false, $callback);

// 等待并接收消息直到程序停止
while ($channel->is_consuming()) {
    $channel->wait();
}

// 关闭连接
$channel->close();
$connection->close();
?>

确保替换连接参数(例如主机名、用户、密码和虚拟主机)以连接到你的RabbitMQ服务器。运行这些脚本,生产者脚本将发送消息到队列,消费者脚本将从队列中接收并处理消息。

相关推荐
catchadmin10 分钟前
PHP 依赖管理器 Composer 2.9 发布
开发语言·php·composer
悠悠~飘24 分钟前
PHP基础-字符串(第16天)
php
一念一花一世界2 小时前
Arbess从初级到进阶(7) - 使用Arbess+GitLab实现PHP项目自动化部署
ci/cd·gitlab·php·arbess
Android系统攻城狮2 小时前
Android内核进阶之获取DMA地址snd_pcm_sgbuf_get_addr:用法实例(九十一)
android·pcm·android内核·音频进阶·pcm硬件参数
清空mega2 小时前
Android Studio移动应用基础教程(前言)
android·ide·android studio
2501_937145413 小时前
2025IPTV 源码优化版实测:双架构兼容 + 可视化运维
android·源码·源代码管理·机顶盒
半旧夜夏3 小时前
【MQ】集群部署和可靠性攻略
rabbitmq
百***99243 小时前
RabbitMQ高级特性----生产者确认机制
分布式·rabbitmq
星光一影4 小时前
废品回收系统小程序源码
mysql·php·html5
曦樂~4 小时前
【Docker】网络
docker·容器·php