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());
    }
}
相关推荐
Y***98515 小时前
【学术会议论文投稿】Spring Boot实战:零基础打造你的Web应用新纪元
前端·spring boot·后端
T***u3335 小时前
JavaScript在Node.js中的流处理大
开发语言·javascript·node.js
q***33375 小时前
SpringMVC新版本踩坑[已解决]
android·前端·后端
武子康5 小时前
大数据-166 Apache Kylin 1.6 Streaming Cubing 实战:Kafka 到分钟级 OLAP
大数据·后端·apache kylin
未来之窗软件服务5 小时前
幽冥大陆(三十四)VUE +node智慧农业电子秤读取——东方仙盟炼气期
开发语言·vue·电子秤·东方仙盟·东方仙盟sdk
回家路上绕了弯5 小时前
彻底解决超卖问题:从单体到分布式的全场景技术方案
分布式·后端
踢球的打工仔6 小时前
PHP面向对象(5)
android·java·php
2501_941802486 小时前
智慧教育平台中的多语言语法引擎与实时学习分析实践
rabbitmq
8***29316 小时前
能懂!基于Springboot的用户增删查改(三层设计模式)
spring boot·后端·设计模式
t***82116 小时前
华为数据中心CE系列交换机级联M-LAG配置示例
服务器·华为·php