大疆无人机如何通过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 等协议这条"高速公路"被运送到您的服务器。

相关推荐
冬奇Lab4 小时前
每日一个开源项目(第140篇):AgentScope 2.0 - 阿里开源的生产级 Agent 框架
人工智能·开源·agent
冬奇Lab4 小时前
Skill 系列(04):Skill 指标体系——L1/L2/L3 三层监控,让质量下降有据可查
人工智能·开源·llm
IT_陈寒5 小时前
Vite的静态资源打包让我熬夜到三点,这坑千万别跳
前端·人工智能·后端
玩转AI不是事6 小时前
用IndexedDB做AI对话离线缓存实战
人工智能
Asize6 小时前
多模态生图:从 Vite 工程化到前端调用 Qwen Image
javascript·人工智能·后端
MobotStone6 小时前
AI项目越多,为什么越容易失控
人工智能·aigc
十有八七6 小时前
AI时代的置身X内
前端·人工智能
Lkstar6 小时前
A2A协议深度解析|Agent2Agent通信标准,智能体互联网的"HTTP"
人工智能·llm
百度Geek说7 小时前
当代码越来越便宜,什么在变贵?
人工智能
橘子星7 小时前
LLM 无状态架构实践:从原理到代码落地
前端·javascript·人工智能