介绍

优质
小牛编辑
133浏览
2023-12-01

ali-iotkit 是 RT-Thread 移植的用于连接阿里云 IoT 平台的软件包。基础 SDK 是阿里提供的 iotkit-embedded C-SDK

物联网套件提供了如下的能力:

  • 嵌入式设备快速接入(设备端SDK)
  • 设备管理
  • 设备和数据信息安全
  • 桥接到阿里云其他产品, 对设备数据存储/计算

阿里云物联网平台场景架构图

在物联网平台场景架构图中,左边物联网设备端 SDK 就是将嵌入式设备连接到阿里云的部分。

软件框架图

iotkit SDK 为了方便设备上云封装了丰富的连接协议,如 MQTT、CoAP、HTTP、TLS,并且对硬件平台进行了抽象,使其不受具体的硬件平台限制而更加灵活。在代码架构方面,iotkit SDK 分为三层,如下图所示:

iotkit SDK 软件框架图

  • 最底层称为硬件平台抽象层, 也简称HAL层(Hardware Abstract Layer)

    抽象不同的嵌入式目标板上,操作系统对SDK的支撑函数,包括网络收发、 TLS/DTLS 通道建立和读写, 内存申请是否和互斥量加锁解锁等。

  • 中间层称为SDK内核实现层(IoT SDK Core Implements)

    物联网平台 C-SDK 的核心实现部分, 它基于 HAL 层接口完成了 MQTT/CoAP 通道等的功能封装, 包括 MQTT 的连接建立、 报文收发、CoAP 的连接建立、报文收发、 OTA 的固件状态查询和 OTA 的固件下载等。

    中间层的封装,使得用户无需关心内部实现逻辑,可以不经修改地应用。

  • 最上层称为SDK接口声明层(IoT SDK Interface Layer)

    最上层是为应用提供 API 的,用户使用该层的 API 完成具体的业务逻辑。

软件包目录结构

ports 目录是 RT-Thread 移植 iotkit-embedded 软件包时所涉及到的移植文件,使用 scons 进行重新构建。

iotkit-embedded 软件包是阿里物联网平台 C-SDK 源码,包含连接阿里云所必须的软件包。

ali-iotkit
|   README.md                       // 软件包使用说明
|   SConscript                      // RT-Thread 默认的构建脚本
+---docs
|   +---figures                     // 文档使用图片
|   |   api.md                      // API 使用说明
|   |   introduction.md             // 软件包详细介绍
|   |   LICENSE                     // 许可证文件
|   |   principle.md                // 实现原理
|   |   README.md                   // 文档结构说明
|   |   samples.md                  // 软件包示例
|   |   user-guide.md               // 使用说明
|   +---version.md                  // 版本说明
+---ports                           // 移植文件
|   +---rtthread                    // OS 相关移植文件
|   +---ssl                         // MbedTLS 相关的移植文件
+---samples
|   +---mqtt                        // MQTT 通道接入阿里云的示例程序
|   +---ota                         // 阿里云 OTA 功能演示例程
+---iotkit-embedded                 // iotkit 源码

iotkit-embedded 软件包目录结构

iotkit-embedded 软件包是阿里物联网平台 C-SDK 源码,未经修改,包含里了连接阿里云 IoT 所必须的软件包。 RT-Thread 移植后,没有使用 iotkit-embedded 中默认的 Makefile 构建脚本,而是使用 scons 重新进行的构建。

iotkit-embedded 软件包目录结构如下所示:

+-- LICENSE           : 软件许可证, Apache-2.0 版本软件许可证
+-- make.settings     : 功能裁剪配置, 如 MQTT|CoAP, 或裁剪如 OTA|Shadow
+-- README.md         : 快速开始导引
+-- sample            : 例程目录, 演示通信模块和服务模块的使用
|   +-- mqtt          :     演示如何使用通信模块 MQTT 的 API
|   +-- coap          :     演示如何使用通信模块 CoAP 的 API
|   +-- device-shadow :     演示如何使用服务模块 DeviceShadow 的 API
|   +-- http          :     演示如何使用通信模块 HTTP 的 API
|   +-- ota           :     演示如何使用服务模块 OTA 的 API
+-- src
    +-- sdk-impl      : SDK 的接口层, 提供总体的头文件, 和一些 API 的接口封装
    +-- sdk-tests     : SDK 的单元测试
    +-- mqtt          : 通信模块, 实现以 MQTT 协议接入
    +-- coap          : 通信模块, 实现以 CoAP 协议接入
    +-- http          : 通信模块, 实现以 HTTP 协议接入
    +-- ota           : 服务模块, 实现基于 MQTT|CoAP+HTTP+TLS 的固件下载通道
    +-- shadow        : 服务模块, 实现设备影子
    +-- platform      : 硬件平台抽象层, 需要移植适配
    +-- import        : 外部输入目录, 存放芯片/模组厂商提供的头文件/二进制库
    +-- configs       : 硬件平台编译配置, 如交叉编译工具链设置, 功能模块裁剪等
    +-- scripts       : 编译过程将要外部引用的脚本, 用户不必关注
    +-- packages      : SDK 引用的外部软件模块, 用户不必关注
    +-- log           : 基础模块, 实现运行日志
    +-- system        : 基础模块, 保存全局信息, 如 TLS 根证书, 设备标识 ID 等
    +-- tls           : 基础模块, 实现 TLS/DTLS, 来自裁剪过的开源软件 mbedtls
    +-- utils         : 基础模块, 实现工具函数, 如 SHA1 摘要计算、NTP 对时等

功能特点

  • 不同网络接入

    提供不同网络的设备接入方案,例如 2/3/4G、NB-IoT、LoRa 等,解决企业异构网络设备接入管理的痛点。

  • 不同协议接入

    提供多种协议的设备 SDK,例如 MQTT、CoAP、HTTP 等,这样既能满足设备需要长连接保证实时性的需求,也能满足设备需要短连接降低功耗的需求。

  • 双向通信

    提供设备与云端的上下行通道,能够稳定可靠的支撑设备上报与指令下发设备的场景。

  • 设备影子

    提供设备影子缓存机制,将设备与应用解耦,解决在无线网络不稳定情况下的通信不可靠痛点。

  • 设备认证

    提供一机一密的设备认证机制,降低设备被攻破的安全风险。

  • 安全传输

    提供 TLS 标准的数据传输通道,保证数据的机密性和完整性。