大疆无人机如何通过MQTT获取实时视频流?

要通过 MQTT 获取大疆无人机的实时视频流,需要理解一个核心原则:视频流本身不通过 MQTT 传输。MQTT 仅用于控制信令,视频流则通过 RTMP、RTSP 等协议推送到流媒体服务器。

以下是基于大疆上云 API 的具体实现方案。


💡 核心原理:信令与视频分离

大疆无人机视频传输遵循以下链路:

无人机 → 遥控器(Pilot 2)/机场(Dock) → 您的云平台

在这个链路中,MQTT 和视频流的职责是分离的:

  • MQTT (控制信令)

    • 作用:用于设备上线、状态上报(OSD)、以及下发直播控制指令(如开始/停止直播、切换镜头)。

    • Topic 示例thing/product/{gateway_sn}/services(用于调用直播服务)。

  • 视频流 (媒体数据)

    • 作用:承载实际的视频画面。

    • 传输协议:通过 RTMP、RTSP、GB28181、Agora(WebRTC) 等协议,由 Pilot 2/Dock 推送到您部署的流媒体服务器。

简单来说,MQTT 负责"发号施令",而视频流则通过独立的"管道"传输。


🚀 实现步骤

1. 准备工作
  • 适用设备:行业无人机(如 M30/M300/M4 系列)及大疆机场,并搭配支持上云 API 的遥控器或机场固件。

  • 平台部署

    • MQTT Broker:如 EMQX。

    • 流媒体服务器:如 Nginx-RTMP, SRS, ZLMediakit。

    • 业务后端:用于处理 MQTT 信令和提供视频播放页面。

  • 设备连接:在 Pilot 2 的"云服务"中配置您的云平台地址,使设备成功接入。

2. 配置流媒体服务器

在您的云服务器上部署并配置好流媒体服务,并开放一个可供 Pilot 2/Dock 访问的推流地址(Endpoint)。

  • 示例 (RTMP)rtmp://your-server-ip/live/drone1

  • 示例 (RTSP)rtsp://your-server-ip:8554/drone1

3. 通过 MQTT 下发直播指令

您的后端服务通过 MQTT 向 Pilot 2/Dock 发送直播控制指令。

  • 订阅服务响应 Topic

    用于接收直播服务的执行结果。

    thing/product/{gateway_sn}/services_reply

  • 调用直播服务 (以 RTMP 为例)

    向服务调用 Topic 发布指令,触发直播。

    • Topic : thing/product/{gateway_sn}/services

    • Method : live_start(具体名称以官方文档为准)

    • Payload 示例:

      json

      {

      "tid": "tid-123456",

      "bid": "bid-123456",

      "method": "live_start",

      "timestamp": 1712345678901,

      "data": {

      "url": "rtmp://your-server-ip/live/drone1",

      "video_type": "rtmp",

      "quality": "1080p"

      }

      }

4. 接收视频流并分发
  1. 接收推流 :Pilot 2/Dock 接收到指令后,会将视频流推送到您在 url中指定的地址。

  2. 转码与分发:您的流媒体服务器接收并管理该流,并可按需转码为 HTTP-FLV、HLS 等格式,供 Web 或移动端播放。

5. 停止直播

同样通过 MQTT 调用 live_stop服务,通知设备停止推流。

  • Topic : thing/product/{gateway_sn}/services

  • Method : live_stop

  • Payload 示例:

    json

    {

    "tid": "tid-789012",

    "bid": "bid-789012",

    "method": "live_stop",

    "timestamp": 1712345678902,

    "data": {

    "url": "rtmp://your-server-ip/live/drone1"

    }

    }


🔗 结合司空 2 平台

如果您使用大疆司空 2,流程类似,但由司空 2 作为中转:

  1. 在司空 2 的"云端互联"中配置您的 RTMP 服务器地址

  2. 通过司空 2 的 REST API 调用"发起码流转发"接口,指定您的 RTMP 地址。

  3. 司空 2 会将码流推送到您的服务器,您再通过 MQTT 订阅司空 2 的事件以获取直播状态。


📊 整体架构与数据流

无人机 → Pilot 2/Dock → (MQTT 信令) → 您的云平台 → (RTMP 视频流) → 您的流媒体服务器 → (HTTP-FLV/HLS) → Web/App

总结来说,MQTT 是"遥控器",负责下达"开始直播"的指令;而视频流是"货物",通过 RTMP 等协议这条"高速公路"被运送到您的服务器。

相关推荐
小锋java123411 小时前
LangChain4j 来了,Java AI智能体开发再次起飞。。。
java·人工智能·后端
一点一一11 小时前
nestjs+langchain:Prompt Template
人工智能·后端
抠脚学代码11 小时前
Linux开发-->驱动开发-->字符设备驱动框架(2)
linux·运维·驱动开发
永霖光电_UVLED12 小时前
1.6T 光模块的能效革命
大数据·人工智能·汽车·娱乐
代码随想录12 小时前
RAG大厂面试题汇总:向量检索、混合检索、Rerank、幻觉处理高频问题
人工智能·大模型·rag·ai应用开发
何中应12 小时前
Promehteus如何指定数据路径
运维·prometheus·监控
热爱Liunx的丘丘人12 小时前
Ansible的Playbook案例一
linux·运维·服务器·ansible
今日说"法"12 小时前
数值计算与浮点误差:深度学习中梯度崩溃的数学根源与归一化对策
人工智能·深度学习
浪客川12 小时前
【百例RUST - 014】Trait
服务器·网络·rust
Minla12 小时前
kubectl常用命令别名设置(linux|windows)
linux·运维·服务器·k8s