一般问题
全部打开Amazon IoT Greengrass 是一项物联网(IoT)开源边缘运行时和云服务,可帮助您构建、部署和管理设备软件。客户在家庭、工厂、车辆和企业中的数百万台设备上为他们的 IoT 应用程序使用 Amazon IoT Greengrass。您可以对设备进行编程,以在本地对生成的数据进行操作,基于机器学习模型执行预测,筛选和聚合设备数据,以及仅将必要的信息传输到云。
利用 Amazon IoT Greengrass,可以快速轻松地构建智能设备软件。 Amazon IoT Greengrass 支持本地处理、消息收发、数据管理、ML 推理,并提供预构建的组件以加速应用程序开发。 Amazon IoT Greengrass 还提供一种将边缘设备无缝连接到我们的任何服务以及第三方服务的安全方法。
软件开发完成后,您可以通过 Amazon IoT Greengrass 远程管理和操作现场设备上的软件,而无需进行固件更新。 Amazon IoT Greengrass 可帮助您的设备保持最新状态,并使其随着时间的推移变得更加智能。
请单击此处查看 Amazon IoT Greengrass 入门指南。
Amazon IoT Greengrass 由一项云服务以及 IoT 设备的两个软件发行版组成:Amazon IoT Greengrass Core、Amazon IoT 设备开发工具包和 Amazon IoT Greengrass 开发工具包。在设备上安装软件发行版后,您可以使用 Amazon IoT Greengrass 进一步添加或删除功能、组件以及管理 IoT 设备应用程序。
下面的图表描述了主要组件。 Amazon IoT Greengrass 还可与 FreeRTOS 一起使用。有关 Amazon IoT Greengrass 和 FreeRTOS 的更多信息,请参阅“常见问题”部分:“将 FreeRTOS 和其他设备连接到 Amazon IoT Greengrass”。
| 目的 | 运行位置
|
|
|---|---|---|
| Amazon IoT Greengrass Core | 提供本地服务(计算、消息收发、状态、安全),并在本地与运行 Amazon IoT 设备开发工具包的设备通信 | 运行通用操作系统(如 Linux)、基于 CPU 的设备(x86 或 Arm) |
| Amazon IoT 设备开发工具包 | 允许设备与 Amazon IoT Greengrass Core 在本地交互 | 几乎所有支持 C++、Node.js、Java 或 Python 2.7、3.7 和 3.8 的设备。 |
| Amazon IoT Greengrass SDK* | 允许 Lambda 函数与 Amazon IoT Greengrass Core 中的本地服务进行交互 | 在部署到 Amazon IoT Greengrass Core 的 Lambda 函数中 |
* 仅 Amazon IoT Greengrass 版本 1 需要
Amazon IoT Greengrass Core 软件可在 IoT 设备、网络集线器或网关上运行,能够自动与云同步和交互。 Amazon IoT Greengrass Core 旨在在配备通用处理器的设备上运行,这种处理器非常强大,能够运行 Linux 等通用操作系统。 Amazon IoT Greengrass 至少需要 1GHz 的计算频率(Arm 或 x86)、96MB* RAM(v2.0 边缘运行时或更高版本)以及其他资源,才能根据使用案例满足所需操作系统、消息吞吐量和 Amazon Lambda 执行的要求。 从 Raspberry Pi 到服务器级设备,Amazon IoT Greengrass Core 可在各种设备上运行。
* 基于使用以下 JDK 的亚马逊云科技研究:用于测试的 JDK 版本:openjdk 版本“1.8.0_275”、OpenJDK 运行时环境(内部版本 1.8.0_275-8u275-b01-0ubuntu1~18.04-b01)和 OpenJDK 64 位服务器 VM(内部版本 25.275-b01,混合模式)。使用不同的输入,内存使用量可能会更高。
受 Amazon IoT Greengrass Core 支持并且经过亚马逊云科技兼容性测试的操作系统和 CPU 架构见此处。
其他 Linux 版本也可以成功运行 IoT Greengrass,但可能未经过 Amazon IoT Greengrass 团队验证。您可以使用 GitHub 上的 IoT Greengrass 依赖项检查器验证其他 Linux 版本的兼容性。或者,您可以在“进程模式”下运行 IoT Greengrass,以降低兼容性阈值,但会删除对 Linux 容器的支持。
您可以在满足最低硬件和软件要求的设备上运行 Amazon IoT Greengrass Core。您还可以使用 Amazon IoT Device Tester 自行对您的设备进行测试,以查看您的设备是否能以最佳方式与 Amazon IoT Greengrass 和其他亚马逊云科技服务结合运行。您还可以在 Amazon Partner Device Catalog 中发现并评估与 Amazon IoT Greengrass 兼容的设备。
为确保您的设备可运行 Amazon IoT Greengrass Core,请通过适用于 Amazon IoT Greengrass 的 Amazon IoT Device Tester 对其进行测试。下载该工具并阅读文档。
您可以在此处查看区域之间的可用性差异。
Amazon IoT Greengrass 支持使用以下语言编写的 Lambda 函数:
- Python 2.7、3.7 和 3.8
- Node v8.10.0 和 v12.x
- Java 8
- C
- C++
- 支持导入 C 库的任何语言
使用 Python 2.7、3.7 或 3.8、Node v8.10.0 或 v12.x 或者 Java 8 Lambda Runtime 的任何 Lambda 都可以部署到 Amazon IoT Greengrass Core。部署到 Amazon IoT Greengrass 的 Lambda 必须与 Amazon IoT Greengrass Core 开发工具包打包在一起。此外,您还可以选择将 Amazon 开发工具包添加到您的 Lambda 软件包中,以便轻松与 Amazon DynamoDB 等服务进行交互。
请注意:当 Amazon IoT Greengrass Core 处于离线模式时,您的 Lambda 所依赖的一些云服务(例如,DynamoDB)将不能供您的 Lambda 函数使用,并且这些服务在离线模式下无法调用 API。此外,如果您在同一软件包中同时包含 Amazon IoT Greengrass Core 开发工具包和 Amazon 开发工具包,则您的 Lambda 函数需要为每种开发工具包使用相应的命名空间。
可以,通过配置 Amazon IoT Greengrass 组无容器化运行,您可以在 Docker 容器中运行 Amazon IoT Greengrass。 您还可以将 Amazon IoT Greengrass 部署为快照,这是一种可在各种 Linux 发行版上运行的容器化软件包。首先,您可以在此处访问 Amazon IoT Greengrass Docker 文件,并且可以在此处查看文档,了解如何从 Amazon ECR 提取 Amazon IoT Greengrass Docker 映像。您还可以将 Amazon IoT Greengrass 部署为快照,这是一种可在各种 Linux 发行版上运行的容器化软件包。首先,您可以在此处访问 Amazon IoT Greengrass 快照,并在此处开始使用。
可以。您可以通过在 Docker 容器组级别运行没有 Amazon IoT Greengrass 容器的 Amazon IoT Greengrass,从而在 Mac OS 或 Windows 上运行 Amazon IoT Greengrass。您可以在我们的文档中详细了解该功能。
适用于云管理的 Amazon IoT Greengrass SLA 规定,如果 Amazon IoT Greengrass 云服务的月度正常运行时间百分比低于 99.9%,您将有资格获得 Amazon IoT Greengrass 提供的可用于部分月度服务费的积分。
如需详细了解 SLA 的所有条款与条件以及如何提交申请,请参阅 Amazon IoT Greengrass SLA 详情页面。
从 Amazon IoT Greengrass 2.0 开始,边缘运行时和几个组件现在是开源组件,并在 GitHub 中发布。有关更多详细信息,请参阅开源组件列表。
可以。Amazon IoT Greengrass 开源边缘运行时根据 Apache 2.0 许可证进行分发,因此可以根据应用程序或项目的具体需求进行修改,而无需获得我们的许可。
否。版本之间的定价没有区别。有关定价的详细信息,请参阅定价页面。
本地资源访问
全部打开“本地资源”是指 Amazon IoT Greengrass 主机上物理存在的总线和外围设备,或 Amazon IoT Greengrass 主机操作系统上的文件系统卷。例如,要与通过 Modbus/CANBUS 连接的设备进行通信,Amazon IoT Greengrass Lambda 函数需要访问设备上的串行端口。本地资源是在 Amazon IoT Greengrass 组范围内定义的,Amazon IoT Greengrass 组中所有 Lambda 都可以使用定义的本地资源。
Amazon IoT Greengrass 本地资源允许 Lambda 函数与硬件(如传感器和执行器)安全交互。例如,您的 Lambda 函数可以从设备上的相机读取视频流,或将命令和控制发送到 GPIO。
安全性
全部打开硬件可信根提供了防篡改可信执行环境,在这种环境中,真随机数生成器可以生成用于加密功能的私钥。这些硬件“安全元件”可以抵御恶意软件篡改,并在物理上绑定到给定的 IoT 设备,从而建立了安全部署软件所依据的强大可信根。
首先,您必须在具有安全元件的边缘设备上运行 Amazon IoT Greengrass Core 软件。按照硬件供应商的指示,在该安全元件上生成私钥。然后,按照文档中的说明来更新 config.json 文件设置以使用安全元件私钥。
安全元件供应商已对其安全元件进行配置,使其通过一套 PKCS#11 标准 API 与 Amazon IoT Greengrass 集成。供应商会使用一组测试工具来验证其硬件配置是否正确。
ML 推理
全部打开您可以将自己训练的 ML 模型以 .tar.gz 和 .zip 格式放置在 Amazon S3 中,从而进行使用。然后,您要让 Amazon IoT Greengrass 了解 S3 URI 和 Amazon IoT Greengrass 将部署到目标设备。
目前,Amazon IoT Greengrass ML 推理在以下亚马逊云科技区域可用:
- Amazon GovCloud(美国西部)
- 美国东部(弗吉尼亚北部)
- 美国西部(俄勒冈)
- 由光环新网运营的亚马逊云科技中国(北京)区域
- 亚洲(东京)
- 亚洲(悉尼)
- 欧洲(法兰克福)
- 欧洲(都柏林)
无论您身处何处,只要您能够访问上述任何一个亚马逊云科技区域,就可以使用 Amazon IoT Greengrass ML 推理功能。
Amazon IoT Greengrass 组件
全部打开Amazon IoT Greengrass 组件是构建块,有助于轻松创建复杂的工作流程,例如机器学习推理、本地处理、消息收发和数据管理。 Amazon IoT Greengrass 还提供预构建的组件,例如支持将数据导出到本地和云目标的 Stream Manager。这些组件有助于加快应用程序开发,因此您无需费心了解设备协议、管理凭证或与外部 API 进行交互,而且无需编写代码即可与我们的服务和第三方应用程序进行交互。此外,您还可以在 Amazon IoT Greengrass 的基础上构建自己的组件。所有组件都旨在实现易用性,因为可以通过 Amazon IoT Greengrass 控制台进行配置和管理。这些组件使您能够在 Amazon IoT Greengrass 设备之间重复使用常见业务逻辑,因为您可以在边缘轻松发现、导入、配置和部署组件。
可在 Amazon IoT Greengrass 控制台中通过每个组的“Components”(组件)部分添加 Amazon IoT Greengrass 组件。添加后,配置 Amazon IoT Greengrass 组件的参数并部署组,即可将它们添加到您的 Amazon IoT Greengrass Core 设备。
所有 Amazon IoT Greengrass 客户都可以在亚马逊云科技管理控制台中使用 Amazon IoT Greengrass 组件。
您可以在我们的文档中查找可用的 Amazon IoT Greengrass 组件。
协议适配器
全部打开您可以为 Amazon IoT Greengrass 创建自定义实施,使您可以使用 OPC-UA 提取和处理来自工业设备的消息。根据您定义的规则,可将消息传输到本地或云目标。您可以从本教程开始,其中显示了 Amazon IoT Greengrass Core 上的自定义 OPC-UA 实施示例。
由于在 Amazon IoT Greengrass Cores 上运行的 Lambda 函数可以访问网络资源,因此您可以使用 Lambda 实现在 TCP/IP 之上实施的任何协议的支持。另外,您还可以利用 Amazon IoT Greengrass 本地资源访问来实现对需要访问硬件适配器/驱动程序的协议的支持。
Amazon IoT Greengrass 还提供 Modbus-RTU、Modbus-TCP 和 Ethernet/IP 协议适配器连接器,可帮助您连接到边缘设备。有关更多信息,请参阅此处的连接器文档。
您可以使用 IoT SiteWise 连接器从 OPC UA 服务器中提取设备数据,使用 Modbus-TCP 连接器从 Modbus-TCP 服务器中提取设备数据,以及使用 Ethernet/IP 连接器从 EtherNet/IP 服务器中提取设备数据。向 Amazon IoT SiteWise 导出数据默认处于启用状态,您可以使用自定义流将数据导出到 Amazon IoT Analytics、Amazon Kinesis 和 Amazon S3。您还可以使用自定义流将数据发送到 Lambda 函数,以便在导出数据之前进行本地处理。或者,您可以创建自定义实施,以使用本地部署的 Lambda 函数提取和处理设备数据,然后将数据传送到本地或云目标。
无线 (OTA) 更新
全部打开亚马逊云科技将不时发布 Amazon IoT Greengrass Core 软件的更新版本以提供下列优势:
- 引入新的或改进的功能
- 漏洞修复
- 提高安全性
借助 Amazon IoT Greengrass 无线更新(OTA),客户无需手动下载和重新安装 Amazon IoT Greengrass Core 软件即可享有所有这些优势。
不。您可以随时选择手动下载和安装更新,或者执行其他的软件部署过程。
当 Amazon IoT Greengrass Core 的新版本可用时,我们将在 Amazon IoT Greengrass 软件开发人员论坛公布。
适用于 Amazon IoT Greengrass 的 Amazon IoT Device Tester
全部打开适用于 Amazon IoT Greengrass 的 Amazon IoT Device Tester 是一个测试自动化工具,可让您在 Linux 设备上自行测试和鉴定 Amazon IoT Greengrass。 Amazon IoT Device Tester 提供一组自动化测试,让您可以确认设备是否可以运行 Amazon IoT Greengrass 并通过 Amazon IoT 服务进行身份验证和互操作。
适用于 Amazon IoT Greengrass 的 Amazon IoT Device Tester 可通过测试以下内容来验证设备的 CPU 架构、Linux 内核配置及驱动程序组合是否可与 Amazon IoT Greengrass 兼容:
- 已安装所需的软件包
- Linux 内核是否包含 Amazon IoT Greengrass 所需内核配置(例如为 CGroups 配置的内核)
- 无线更新
- 设备可连接 IoT 服务且能够运行 Amazon Lambda 函数
- 本地资源访问功能
- Device Shadow 功能
适用于 Amazon IoT Greengrass 的 Amazon IoT Device Tester 在已推出 Amazon IoT Greengrass 的所有区域可用。
适用于 Amazon IoT Greengrass 的 Amazon IoT Device Tester 免费供您使用。不过,您需要承担测试过程中与亚马逊云科技使用相关的所有费用。在单个 Amazon IoT Greengrass 设备上运行一次 Amazon IoT Device Tester 测试所需的费用将不到 2 元。
将 FreeRTOS 和其他设备连接到 Amazon IoT Greengrass
全部打开可以使用 FreeRTOS 或 Amazon IoT 设备开发工具包在本地将设备连接到 Amazon IoT Greengrass Core。 Amazon IoT Greengrass 发现可通过 C++、Node.js、Java 以及 Python 2.7、3.7 和 3.8 在 Amazon IoT 设备开发工具包上使用。有关更多信息,请参阅 Amazon IoT Greengrass 用户指南。您可以在 FreeRTOS 源代码中使用 Amazon IoT Greengrass 发现库,来查找并连接 Amazon IoT Greengrass Core 设备。
Amazon IoT Greengrass 发现可通过 C++ 以及 Python 2.7 和 3.7 在 Amazon IoT 设备开发工具包上使用。有关更多信息,请参阅 Amazon IoT Greengrass 开发人员指南。
可以。FreeRTOS 设备可以直接连接到云或连接到 Amazon IoT Greengrass。 FreeRTOS 在 IoT 端点上运行,通常负责 IoT 拓扑中的“感知”和“行为”。
Amazon IoT Greengrass 是一种允许您以安全方式在互联设备上运行本地计算、消息收发、数据缓存、同步和 ML 推理功能的软件。借助 Amazon IoT Greengrass,互联设备可以运行 Amazon Lambda 函数、同步设备数据,以及与其他设备安全通信 — 甚至无需连接互联网。通过使用 Amazon Lambda,Amazon IoT Greengrass 可以确保您的 IoT 设备能够快速响应本地事件,使用在 Amazon IoT Greengrass Core 上运行的 Lambda 函数与本地资源进行交互,执行间歇性连接,通过无线更新保持更新状态,最大限度地降低将 IoT 数据传输到云的成本。
FreeRTOS 是用于微控制器的开源操作系统,在边缘站点运行,一般不支持可运行 Amazon IoT Greengrass 的芯片组。这些微控制器设备可用于各种 IoT 端点,如健身追踪器、起搏器、电表、汽车传动设备和传感器网络。FreeRTOS 设备无法运行 Amazon IoT Greengrass Core,但可以在 IoT Greengrass Core 设备之间连接、发送和接收消息,以在边缘进行本地处理。
这两个设备的硬件要求和操作系统是不同的。
| FreeRTOS | Amazon IoT Greengrass | |
|---|---|---|
| 软件 | 操作系统,在微控制器上运行 | 适用于 Linux 设备的运行时和适用于 Amazon IoT Greengrass 感知设备的开发工具包 |
| 硬件要求 | >64KB RAM | >96MB* RAM(v2.0 边缘运行时或更高版本)
>128MB RAM(v1.11 边缘运行时或更低版本) |
| 类别 | 嵌入式系统、IoT 终端节点 | 边缘设备、本地网关 |
| 使用案例 | 基于微控制器的设备 | 工业自动化系统、无线路由器、摄像机、网关 |
* 基于使用以下 JDK 的亚马逊云科技研究:用于测试的 JDK 版本:openjdk 版本“1.8.0_275”、OpenJDK 运行时环境(内部版本 1.8.0_275-8u275-b01-0ubuntu1~18.04-b01)和 OpenJDK 64 位服务器 VM(内部版本 25.275-b01,混合模式)。使用不同的输入,内存使用量可能会更高。