摘要:该场景主要描述的是设备可以通过MQTT协议与物联网平台进行交互,用户可以在控制台产品详情中自定义Topic,通过应用侧接口或控制台创建数据转发规则,把设备上报的消息转发给其他华为云服务,供应用侧用户主动去消费。

场景简介

已对接存量设备的网关,不用迁移就可以实现对既有设备和新设备的兼容控制。

该场景主要描述的是设备可以通过MQTT协议与物联网平台进行交互,用户可以在控制台产品详情中自定义Topic,通过应用侧接口或控制台创建数据转发规则,把设备上报的消息转发给其他华为云服务,供应用侧用户主动去消费。

核心知识点:产品模型、消息上报、消息下发、MQTT协议、数据转发规则、自定义Topic。

场景流程

流程解释:

1.创建网关产品:物联网平台是以产品为粒度管理批量设备,产品的创建与管理,可以通过平台提供的API接口或控制台

2.自定义topic:您可以在产品详情中自定义topic,该产品下的所有设备都将可以通过自定义topic,与平台间进行数据上下行交互。

3.注册网关设备:平台提供了应用侧API接口可以之策设备,也可以通过控制台注册。注册的设备ID,是设备侧与平台交互的唯一标识。这里是用手机APP进行应用侧接口调用注册,就如前面概念串联时提到的,应用侧不局限于web服务端。

4.创建数据转发规则:网关APP可以通过API接口创建规则,也可以通过控制台创建,指定过滤指定的属性,给指定的通道转发数据。

5.开通DIS通道/OBS服务:华为公有云上有丰富的SaaS服务和PaaS服务,供您结合自己的业务需要进行组合使用。DIS服务提供高效采集、传输、分发能力,支持多种IoT协议,OBS服务提供海量、安全、高可靠、低成本的数据存储能力,可以开通该两个服务(或之一),通过IoTDA规则引擎,把网关的数据转发给DIS/OBS。

6.设备建链:MQTT设备是指通过MQTT协议接入的设备,不论是集成了华为IoT Device SDK,还是原生MQTT协议接入,只要是json数据格式传输给平台,平台就无需使用编解码插件。如果是二进制上传,则需要先做编解码插件的开发。MQTT是长连接,需要先建链才能进行数据传输,可以通过安全加密方式8883端口接入(推荐),也可以通过非安全加密方式1883端口接入。

7.订阅消息下发Topic:MQTT设备与平台建立长连接后,可以订阅平台下行的topic,实现对平台下发消息的实时监听。

8.网关消息上报:网关设备把数据透传到平台,由平台不做任何处理按规则转发给DIS/OBS等存储通道。消息跟属性的主要区别是不用指定产品模型,平台对上报的消息不做处理(包括存储和快照都没有),仅做纯数据转发。

9.按规则数据转发:平台收到设备上报的属性后,规则引擎会进行过滤(不论属性还是消息,平台都会做规则过滤),把设定好的消息值转发到指定的DIS通道,放到消息队列中。或者转发到OBS做对象存储。

10.消费消息数据:由于平台对消息仅做透传,而且APP无法配置订阅通知的callback url,所以将设备上报的数据通过消息转储到DIS/OBS,再由APP调用DIS/OBS的接口或集成SDK,消费设备数据,进而实现对网关设备上报消息的接收。

11.消息下发:网关APP通过应用侧接口下发消息,平台同样不会做任何的处理,消息下发是异步的,不用等到设备侧网关的响应。

12.消息下发:平台通过消息下发的下行topic把消息透传给网关。这个需要前面网关设备订阅了消息下发的topic,否则接收不到平台下行消息。

最佳实践

场景说明

自定义Topic功能用于MQTT协议设备接入物联网平台的场景,支持设备消息上报、平台消息下发的Topic进行自定义。根据Topic不同,应用侧可实现不同的业务逻辑处理,也适用于应用侧和设备侧之间,设备无法按照产品模型中定义的属性或命令进行数据上报的场景。

本示例中,应用服务器收到设备上报Topic为室内温度的数据,判断是否开启或关闭室内空调。

新增自定义Topic

具体操作细节请参考新增自定义Topic

1、在产品详情页中,选择“可选配置”页签,点击“新增自定义topic”按钮。

2、在弹出的页面中,选择设备操作权限,填写topic名称。

3、点击“确认”,完成新增自定义topic。

自定义Topic添加成功后,您可以在自定义topic列表执行修改和删除操作。

MQTT设备消息上报

1、登录控制台,进入指定设备详情页,启动消息跟踪。

2、以MQTT.fx模拟器(请参考设备快速接入)为例,模拟设备上报自定义Topic消息。

使用IoT Device SDK或原生MQTT协议接入的设备,需要在设备程序中,设置设备上报的自定义Topic名称。

3、登录控制台,在设备详情消息跟踪页面,查看设备上报的自定义Topic消息。

4、应用侧通过数据转发的方式,获取MQTT设备上报的自定义Topic消息。更多数据转发方式,请参考数据转发。您也可以参考最佳实践案例数据转发到OBS长期存储

MQTT设备消息下发

应用侧收到MQTT设备上报的自定义Topic消息后,需要进行相应的业务处理。本示例通过自定义Topic,下发开启室内空调指令。

MQTT设备需要先订阅自定义Topic,才可以接收应用侧下发的自定义Topic消息。

  • 确保创建自定义Topic时,设备操作权限包含“订阅”功能,详细操作请参考设备操作权限
  • 使用IoT Device SDK或者原生MQTT协议接入的设备,需要在设备程序中,设置设备订阅的自定义Topic名称。

1、本文使用postman工具模拟应用侧调用下发设备消息接口,下发开启室内空调的命令。

2、调用查询设备消息接口,查看下发命令是否成功。

至此,通过该文档的学习,您应该对智能网关和自定义Topic场景有了一定的了解。接下来,可以在系列后续文章中,可以学习到更多的物联网业务场景。

点击关注,第一时间了解华为云新鲜技术~

干货分享丨玩转物联网IoTDA服务系列四-智能网关的更多相关文章

  1. 干货分享丨玩转物联网IoTDA服务系列五-智能家居煤气检测联动

    摘要:该场景主要描述的是设备可以通过LWM2M协议与物联网平台进行交互,用户可以在控制台或通过应用侧接口创建设备联动规则,把设备上报的属性转发,通过物联网平台规则引擎转变成命令下发给其他指定设备. 场 ...

  2. 玩转华为物联网IoTDA服务系列三-自动售货机销售分析场景示例

    场景简介 通过收集自动售货机系统的销售数据,EI数据分析售货销量状况. 该场景主要描述的是设备可以通过MQTT协议与物联网平台进行交互,应用侧可以到物联网平台订阅设备侧变化的通知,用户可以在控制台或通 ...

  3. 国内物联网平台(5):机智云IoT物联网云服务平台及智能硬件自助开发平台

    国内物联网平台(5)——机智云IoT物联网云服务平台及智能硬件自助开发平台 马智 平台定位 机智云平台是致力于物联网.智能硬件云服务的开放平台.平台提供了从定义产品.设备端开发调试.应用开发.产测.运 ...

  4. 干货分享丨jvm系列:dump文件深度分析

    摘要:java内存dump是jvm运行时内存的一份快照,利用它可以分析是否存在内存浪费,可以检查内存管理是否合理,当发生OOM的时候,可以找出问题的原因.那么dump文件的内容是什么样的呢? JVM ...

  5. 【腾讯Bugly干货分享】微信终端跨平台组件 Mars 系列 - 我们如约而至

    导语 昨天上午,微信在广州举办了微信公开课Pro.于是,精神哥这两天的朋友圈被小龙的"八不做"刷屏了.小伙伴们可能不知道,下午,微信公开课专门开设了技术分论坛.在分论坛中,微信开源 ...

  6. 国内物联网平台初探(五) ——机智云IoT物联网云服务平台及智能硬件自助开发平台

    平台定位 机智云平台是致力于物联网.智能硬件云服务的开放平台.平台提供了从定义产品.设备端开发调试.应用开发.产测.运营管理等覆盖智能硬件接入到运营管理全生命周期服务的能力. 机智云平台为开发者提供了 ...

  7. 【腾讯Bugly干货分享】微信终端跨平台组件 mars 系列(二) - 信令传输超时设计

    本文来自于腾讯Bugly公众号(weixinBugly),未经作者同意,请勿转载,原文地址:http://mp.weixin.qq.com/s/9DJxipJaaBC8yC-buHgnTQ 作者简介: ...

  8. 【腾讯Bugly干货分享】微信终端跨平台组件 mars 系列(一) - 高性能日志模块xlog

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57ff5932cde42f1f03de29b1 本文来源: 微信客户端开发团队 ...

  9. go微服务系列(四) - gRPC入门

    1. 前言 2. gRPC与Protobuf简介 3. 安装 4. 中间文件演示 4.1 编写中间文件 4.2 运行protoc命令编译成go中间文件 5. 创建gRPC服务端 5.1 新建Produ ...

随机推荐

  1. Illegal reflective access by org.apache.hadoop.security.authentication.util.KerberosUtil

    在使用Java API操作HBase时抛出如下异常: Illegal reflective access by org.apache.hadoop.security.authentication.ut ...

  2. Python实用笔记 (17)模块

    一个abc.py的文件就是一个名字叫abc的模块,一个xyz.py的文件就是一个名字叫xyz的模块. 现在,假设我们的abc和xyz这两个模块名字与其他模块冲突了,于是我们可以通过包来组织模块,避免冲 ...

  3. ajax前后端交互原理(1)

    1.Node.js简介 1.1.前后台数据交互流程 在web开发中,我们经常听说前端和后台,他们分别是做什么具体工作的呢?他们怎样交互的呢?我们得把这些基础的问题都搞明白了,才有一个大致的学习方向,首 ...

  4. 使用CImage双缓冲

    一普通显示:现在的VC显示图片非常方便,远不是VC6.0那个年代的技术可比,而且支持多种格式的如JPG,PNG. CImage _img; 初始化: _img.Load(L"map.png& ...

  5. NPOI 操作数据库中数据的导入导出(Excel.xls文件) 和null数据的处理。

    App.config: <?xml version="1.0" encoding="utf-8" ?> <configuration> ...

  6. 浏览器的回流与重绘 (Reflow & Repaint)

    写在前面 在讨论回流与重绘之前,我们要知道: 浏览器使用流式布局模型 (Flow Based Layout). 浏览器会把HTML解析成DOM,把CSS解析成CSSOM,DOM和CSSOM合并就产生了 ...

  7. activiti6基础01-如何数据库操作及相关表

    官网文档:https://www.activiti.org/userguide/#queryAPI 1. Activit的简单源码解读      activiti的官方文档讲解详细很详细,也很范.按着 ...

  8. locust接口压测

    前言: locust是完全基于python,是一个简单易用的分布式负载测试工具 Locust特性 使用Python编写模拟用户行为的代码,无需繁琐的配置 分布式可扩展,能够支持上百万用户 自带Web界 ...

  9. 07 . Jenkins忘记root密码

    重置Jenkins用户名密码 忘记用户名密码(如图)不管是忘记用户名密码还是误删jenkins目录下的users文件都可以使用下面的方式找回密码,我的版本是Jenkins 2.134 配置config ...

  10. day39 进程

    目录 一.进程对象的其他方法 二.僵尸进程与孤儿进程(了解) 1 僵尸进程 2 孤儿进程 三.守护进程 四.互斥锁 五.进程间通信 六.IPC机制 七.生产者消费者模型 八.线程理论 一.进程对象的其 ...