PHP 使用RabbitMq推送消息

复制代码
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;
复制代码
config.php 文件
复制代码
"order_dispose" => [
    "routingKey" => "xxx",
    "name" => "xxx",
    //"class" => \app\rmq\pull\xxx::class,
    "exchange" => [
        "name" => "xxx",
        "type" => "topic", #exchange类型,可以是direct、topic、headers或fanout之一。
        "passive" => false, #如果设置为true,则不会创建exchange,仅检查是否存在指定名称的exchange。
        "durable" => true, #如果设置为true,则exchange将在重启后继续存在。
        "auto_delete" => false, #如果设置为true,则exchange将在最后一个绑定被删除后自动删除。
        "internal" => false,#如果设置为true,则exchange将用于内部用途,不允许客户端发布消息到该exchange。
    ],
    /*"queue" => [
        "name" => "xxx", #队列名称
        "passive" => false, #如果为true,则不会创建队列。如果队列不存在,则会返回一个错误
        "durable" => true, #如果为true,则队列将被持久化。当RabbitMQ服务器重启时,队列将保留下来
        "exclusive" => false, #如果为true,则队列只能被当前连接使用,当连接关闭时队列将被删除。该选项通常用于创建临时队列。
        "auto_delete" => false, #如果设置为true,则exchange将在最后一个绑定被删除后自动删除。
    ],*/
复制代码
//实现方式

/**
 * @throws \Exception
 */
public static function publisherMessage($data)
{
    // json格式数据
    $msgBody = json_encode($data);

    // 日志记录
    Log::info("rabbitmq推送订单信息" . $msgBody);

    try {
        $config = config('rabbitmq.AMQP');

        // 创建连接和通道
        $connection = new AMQPStreamConnection($config["host"], $config["port"], $config["user"], $config["password"], $config["vhost"], false, 'AMQPLAIN', null, 'en_US', 30, 60, null, false, 30);
        $channel = $connection->channel();

        // 声明交换机
        $listen_config = config("rabbitmq.Listening.order_dispose");
        $channel->exchange_declare($listen_config["exchange"]["name"], $listen_config["exchange"]["type"], $listen_config["exchange"]["passive"], $listen_config["exchange"]["durable"], $listen_config["exchange"]["auto_delete"], $listen_config["exchange"]["internal"]);

        // 创建消息
        $properties = ['content_type' => 'application/json', 'delivery_mode' => AMQPMessage::DELIVERY_MODE_PERSISTENT];
        $msg = new AMQPMessage($msgBody, $properties);

        // 发送消息到交换机
        $channel->basic_publish($msg, $listen_config["exchange"]["name"], $listen_config["routingKey"]);
        //echo " [x] Sent '$msgBody'\n";

        // 关闭通道和连接
        $channel->close();
        $connection->close();
    } catch (\Exception $e) {
        Log::info("MQ推送订单数据失败,订单信息:" . $msgBody . ',错误信息:' . $e->getMessage());
    }
}
相关推荐
APIshop30 分钟前
Java获取item_get-获得某书商品详情接口
java·开发语言·python
Henry Zhu1231 小时前
Qt Model/View架构详解(四):高级特性
开发语言·qt·架构
sunnyday04261 小时前
Spring Boot 自定义 Starter 实战:从创建到使用的完整指南
spring boot·后端·mybatis
txinyu的博客1 小时前
std::function
服务器·开发语言·c++
多多*1 小时前
图解Redis的分布式锁的历程 从单机到集群
java·开发语言·javascript·vue.js·spring·tomcat·maven
想用offer打牌1 小时前
2025年总结:一个树苗倔强生长
java·后端·开源·go
电商API&Tina2 小时前
Python请求淘宝商品评论API接口全指南||taobao评论API
java·开发语言·数据库·python·json·php
小北方城市网2 小时前
Redis 分布式锁与缓存三大问题解决方案
spring boot·redis·分布式·后端·缓存·wpf·mybatis
学嵌入式的小杨同学2 小时前
【嵌入式 C 语言实战】交互式栈管理系统:从功能实现到用户交互全解析
c语言·开发语言·arm开发·数据结构·c++·算法·链表
哪里不会点哪里.2 小时前
Spring 核心原理解析:它到底解决了什么问题?
java·后端·spring