当前位置: 首页 > news >正文

爱智EdgerOS之深入解析安全可靠的开放协议SDDC

一、协议简介

  • 在 EdgerOS 的智慧生态场景中,许多智能设备或传感器的生命周期都与 SDDC 协议息息相关,这些设备可能是使用 libsddc 智能配网技术开发的,也有可能是因为主要功能上是使用其他技术如 MQTT、LoRa 等但是设备的上下线依然是使用上述的技术。
  • SDDC(Smart Device Discovery & Control,智能设备发现与控制)是 EdgerOS 专门为 Wi-Fi 和以太网通信技术的物联网设备定义的发现与控制通信协议。使用 SDDC 协议开发的物联网设备能被 EdgerOS 自动管理,因此推荐 Wi-Fi 和以太网通信技术的物联网设备使用 SDDC 协议与 EdgerOS 通信。
  • SDDC 协议实现了以下功能:
    • EdgerOS 发现设备;
    • EdgerOS 邀请设备加入;
    • 设备加入和退出 EdgerOS;
    • EdgerOS 维持设备 Online 状态;
    • EdgerOS 与设备间的双向数据通信,数据可加密,支持带有消息重传和确认的可靠通信方式。
  • SDDC 协议流程如下图:

在这里插入图片描述

二、协议的实现原理

  • SDDC 协议是基于 UDP 协议实现的,如图所示,UDP 报文的数据部分的前 16 个字节实际上就是 SDDC 数据报的头部:

在这里插入图片描述

  • 对于 SDDC 协议的头部来说,它的结构组成如下:

在这里插入图片描述

  • 说明:
    • magic_version 标志着 SDDC 协议的版本号;
    • flag 分别为 0x00(无标志)、0x10(紧急标志)、0x20(加入标志)、0x40(请求标志)、0x80(确认标志);
    • type 分别为 0x00(Discover 消息)、0x01( Report 消息)、0x02(更新消息)、0x03(邀请消息)、0x04(PING消息)、0x05(普通消息)、0x60(系统时间消息);
    • seq_no:SDDC 数据报的序列号;
    • MAC[0]-MAC[2] 和 MAC[3]-MAC[5]:设备的6字节MAC地址数组;
    • security:选择是否进行加密通信,设备也可以通过此标志位设置使用设备密码;
    • data_len:sddc payload 的长度。

三、协议的实现流程

  • Spirit 1(Spirit 1 是翼辉爱智推出的一款高性能、高速率、高可靠、低延时的智能边缘计算机) 在广播地址发送一个值为 1500568c409505fe800004b700000000 的 UDP 报文,其中 flag_type 为 00 ,代表这是一条发送到所有连接到 Spirit 1 的网络的设备的【发现】报文,用于搜索所有的 SDDC 设备。
  • 设备收到 Discover 消息,会回复一条 flag_type 为 01 代表 Report 消息的 UDP 报文。

在这里插入图片描述

  • Spirit 1 邀请设备加入到自己的设备组。
  • 在加入之后,普通消息一般为 flag_type 为 45 的 UDP 报文 ,如下是 Spirit 1 向设备发送的消息,其中 flag 为 4 代表请求包,type 为 5 代表普通消息,且 seq_no 标志为 67 95:

在这里插入图片描述

  • 设备收到消息后,会对消息进行处理,假如需要确认则会回复一个确认包。flag_type 为 84,其中 flag 为 8 代表确认包,type 为 5 代表普通消息,且 seq_no 标志为 67 95 ,代表回复的是 67 95 的确认包。我们知道 UDP 数据报是无连接的,SDDC 协议使用 seq_no 机制可以保证数据有序。

在这里插入图片描述

  • 当 Spirit 1 和 设备没有进行消息传送的时候, Spirit 1 会发送 flag_type 为 44 的请求 PING 包,等待来自远程设备的回复。当远程设备未回复时,系统将自动重新发送此消息,直到远程设备响应或超时。

在这里插入图片描述

  • 当设备收到请求 PING 包时,设备会向该 seq_no 的包回复一个 flag_type 为 84 的 确认包,这样 Spirit 1 就知道设备还在线。

四、更多

  • SDDC 数据报是基于 UDP 协议实现,该通信协议免费开源,实现简单,可以有效降低开发成本,在 UDP 的基础上做到了安全可靠、有序到达,除此之外还有许多功能,比如可以发送时间戳消息,这样没有 RTC 芯片的无状态设备也可以同步网络时间;可以发送紧急消息,这样设备或系统可以优先处理等。

相关文章:

  • Spring--10--Spring Bean的生命周期
  • 应用密码学期末复习(3)
  • 如何使用GaussDB创建外表(FOREIGN TABLE)
  • STM32超声波——HC_SR04
  • 解读 | 为什么有很多名人让人们警惕人工智能
  • 【NR技术】NR NG-RAN整体架构 -功能划分(三)
  • 人工智能|深度学习——知识蒸馏
  • 基于单片机的定时插座在智能家居中的应用
  • Linux ln命令教程:如何创建符号链接(附案例详解和注意事项)
  • 双荧光素酶报告基因检测(五)
  • 大模型应用_AutoGPT
  • viple与物理机器人(一):线控模拟
  • MySQL InnoDB Replication部署方案与实践
  • EMQX(5.3.1)多机集群部署
  • 总结6种@Transactional注解的失效场景
  • @angular/forms 源码解析之双向绑定
  • 【347天】每日项目总结系列085(2018.01.18)
  • C语言笔记(第一章:C语言编程)
  • hadoop集群管理系统搭建规划说明
  • jquery cookie
  • Linux编程学习笔记 | Linux多线程学习[2] - 线程的同步
  • Logstash 参考指南(目录)
  • Mysql优化
  • 阿里云购买磁盘后挂载
  • 道格拉斯-普克 抽稀算法 附javascript实现
  • 干货 | 以太坊Mist负责人教你建立无服务器应用
  • 如何实现 font-size 的响应式
  • 使用SAX解析XML
  • 算法-图和图算法
  • 为视图添加丝滑的水波纹
  • 无服务器化是企业 IT 架构的未来吗?
  • 新手搭建网站的主要流程
  • #1015 : KMP算法
  • #我与Java虚拟机的故事#连载19:等我技术变强了,我会去看你的 ​
  • ${ }的特别功能
  • (1)Map集合 (2)异常机制 (3)File类 (4)I/O流
  • (NO.00004)iOS实现打砖块游戏(十二):伸缩自如,我是如意金箍棒(上)!
  • (Redis使用系列) Springboot 实现Redis 同数据源动态切换db 八
  • (WSI分类)WSI分类文献小综述 2024
  • (层次遍历)104. 二叉树的最大深度
  • (附源码)springboot青少年公共卫生教育平台 毕业设计 643214
  • (机器学习的矩阵)(向量、矩阵与多元线性回归)
  • (四)linux文件内容查看
  • (转)shell调试方法
  • *p++,*(p++),*++p,(*p)++区别?
  • .NET “底层”异步编程模式——异步编程模型(Asynchronous Programming Model,APM)...
  • .net refrector
  • .NET 中使用 Mutex 进行跨越进程边界的同步
  • .Net+SQL Server企业应用性能优化笔记4——精确查找瓶颈
  • .Net下C#针对Excel开发控件汇总(ClosedXML,EPPlus,NPOI)
  • .net中生成excel后调整宽度
  • @converter 只能用mysql吗_python-MySQLConverter对象没有mysql-connector属性’...
  • @软考考生,这份软考高分攻略你须知道
  • [ Linux 长征路第二篇] 基本指令head,tail,date,cal,find,grep,zip,tar,bc,unname
  • [20161214]如何确定dbid.txt