Amazon IoT Greengrass Version 12023 年 6 月 30 日进入延长寿命阶段。有关更多信息,请参阅Amazon IoT Greengrass V1维护政策。在此日期之后,Amazon IoT Greengrass V1不会发布提供功能、增强功能、错误修复或安全补丁的更新。在上运行的设备Amazon IoT Greengrass V1不会受到干扰,将继续运行并连接到云端。我们强烈建议你迁移到Amazon IoT Greengrass Version 2,它补充说重要的新功能和支持其他平台。
本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
Greengrass 连接器入门(控制台)
此功能适用于以下项目Amazon IoT GreengrassCore v1.7 及更高版本。
本教程介绍如何通过 Amazon Web Services Management Console 使用连接器。
使用连接器可加快开发生命周期。连接器是预先构建、可重复使用的模块,可以更加轻松地与服务、协议和资源进行交互。它们可以帮助您将业务逻辑更快地部署到 Greengrass 设备。有关更多信息,请参阅 使用 Greengrass 连接器与服务和协议集成。
在本教程中,您将配置和部署Twilio 通知连接器。连接器接收 Twilio 消息信息作为输入数据,然后触发 Twilio 文本消息。下图中将显示数据流。

配置连接器后,您便可创建 Lambda 函数和订阅。
该函数将评估来自温度传感器的模拟数据。它有条件地将 Twilio 消息信息发布到 MQTT 主题。这是连接器订阅的主题。
该订阅允许函数发布到主题,并允许连接器接收来自该主题的数据。
Twilio 通知连接器需要 Twilio 身份验证令牌,才能与 Twilio API 进行交互。令牌是在 Amazon Secrets Manager 中创建且从组资源中引用的文本类型密钥。这样一来,Amazon IoT Greengrass 便可在 Greengrass 核心上创建密钥的本地副本,在该核心中,此类副本经过加密且可供连接器使用。有关更多信息,请参阅 将密钥部署到 Amazon IoT Greengrass 核心。
本教程包含以下概括步骤:
完成本教程大约需要 20 分钟。
先决条件
要完成此教程,需要:
-
Greengrass 组和 Greengrass Core(v1.9.3 或更高版本)。要了解如何创建 Greengrass 组和核心,请参阅 Amazon IoT Greengrass 入门。“入门”教程还包含用于安装 Amazon IoT Greengrass Core 软件的步骤。
-
安装在 Amazon IoT Greengrass 核心设备上的 Python 3.7。
-
Amazon IoT Greengrass必须配置为支持本地密钥,如中所述密钥要求.
注意
此要求包括允许访问您的Secrets Manager 密钥。如果使用的是默认 Greengrass 服务角色,Greengrass 有权获取密钥,其名称以greengrass.
-
Twilio 账户 SID、身份验证令牌和支持 Twilio 的电话号码。创建 Twilio 项目后,项目控制面板上会显示这些值。
注意
您可以使用 Twilio 试用账户。如果您使用的是试用账户,则必须将非 Twilio 收款人的电话号码添加到已验证的电话号码列表中。有关更多信息,请参阅 。如何使用您的免费 Twilio 试用账户
.
第 1 步:创建Secrets Manager 密钥
在此步骤中,您将使用 Amazon Secrets Manager 控制台为 Twilio 身份验证令牌创建一个文本类型密钥。
-
登录到 Amazon Secrets Manager 控制台
。 注意
有关此过程的更多信息,请参阅第 1 步:在中创建并存储密钥Amazon Secrets Manager中的Amazon Secrets Manager用户指南.
-
选择 Store a new secret (存储新密钥)。
-
UNDER选择密钥类型,选择其他密钥类型.
-
UNDER指定要为此密钥存储的键值对,在明文选项卡中,输入您的 Twilio 身份验证令牌。删除所有 JSON 格式设置,然后仅输入令牌值。
-
保持aws/smanager为加密密钥保持选中,然后选择下一步.
注意
您不会被收费Amazon KMS如果你使用默认值AmazonSecrets Manager 在您的账户中创建的托管密钥。
-
对于密钥名称,输入
greengrass-TwilioAuthToken
,然后选择下一步。注意
默认情况下,Greengrass 服务角色允许Amazon IoT Greengrass获取名称以开头的 secretsgreengrass. 有关更多信息,请参阅密钥要求。
-
本教程不需要轮换,因此,请选择 Disable automatic rotation (禁用自动轮换)下一步.
-
在 Review (审核) 页上,审核您的设置,然后选择 Store (存储)。
接下来,在 Greengrass 组中创建一个引用该密钥的密钥资源。
第 2 步:将密钥资源添加到 Greengrass 组
在此步骤中,您将一个密钥资源 添加到 Greengrass 组。该资源是对上一步中创建的密钥的引用。
在Amazon IoT控制台导航窗格,在Manage,展开Greengrass,然后选择组 (V1).
-
选择要将密钥资源添加到的组。
-
在组配置页面上,选择资源选项卡,然后向下滚动到Secrets部分。这些区域有:Secrets部分显示属于该组的密钥资源。您可以从此部分添加、编辑和删除密钥资源。
注意
或者,控制台允许您在配置连接器或 Lambda 函数时创建密钥和密钥资源。您可通过连接器完成这一操作配置参数页面或 Lambda 函数的资源页.
-
选择Add在Secrets部分。
-
在存储库的添加密钥资源页面,输入
MyTwilioAuthToken
(对于 )资源名称. -
对于密钥,选择greengrassTwilioAuthToken.
-
在选择标签(可选)部分 AWSCURRENT 暂存标签表示最新版密钥。该标签始终包含在密钥资源中。
注意
本教程要求 AWSCURRENT 仅标签。您可以视情况包括 Lambda 函数或连接器所需的标签。
-
选择 Add resource (添加资源)。
第 3 步:将连接器添加到 Greengrass 组
在此步骤中,您将为Twilio 通知连接器并将其添加到组。
-
在组配置页面上,选择 Connectors (连接器),然后选择 Add a connector (添加连接器)。
-
在存储库的添加连接器页面,选择Twilio 通知.
-
选择 版本。
-
在配置部分:
-
适用于Twilio 身份验证令牌资源,输入在先前步骤中创建的资源。
注意
当您输入资源时,Twilio 身份验证令牌密钥的 ARN已为您填充属性。
-
对于 Default from phone number (默认的来电号码),输入您的支持 Twilio 的电话号码。
-
对于 Twilio account SID (Twilio 账户 SID),输入您的 Twilio 账户 SID。
-
-
选择 Add resource (添加资源)。
第 4 步:创建 Lambda 函数部署软件包
要创建 Lambda 函数,您必须先创建一个 Lambda 函数部署程序包包含函数代码和依赖项。Greengrass Lambda 函数需要Amazon IoT Greengrass核心开发工具包用于在核心环境中与 MQTT 消息通信和访问本地密钥等任务。本教程将创建一个 Python 函数,因此您在部署包中使用 Python 版本的开发工具包。
-
从Amazon IoT Greengrass核心开发工具包下载页面,下载Amazon IoT Greengrass适用于 Python 的核心 SDK 连接到你的计算机。
-
解压缩下载的程序包以获取软件开发工具包。软件开发工具包是
greengrasssdk
文件夹。 -
将以下 Python 代码函数保存在名为
temp_monitor.py
的本地文件中。import greengrasssdk import json import random client = greengrasssdk.client('iot-data') # publish to the Twilio Notifications connector through the twilio/txt topic def function_handler(event, context): temp = event['temperature'] # check the temperature # if greater than 30C, send a notification if temp > 30: data = build_request(event) client.publish(topic='twilio/txt', payload=json.dumps(data)) print('published:' + str(data)) print('temperature:' + str(temp)) return # build the Twilio request from the input data def build_request(event): to_name = event['to_name'] to_number = event['to_number'] temp_report = 'temperature:' + str(event['temperature']) return { "request": { "recipient": { "name": to_name, "phone_number": to_number, "message": temp_report } }, "id": "request_" + str(random.randint(1,101)) }
-
将以下项目压缩到名为
temp_monitor_python.zip
的文件中。在创建 ZIP 文件时,仅包含代码和依赖项,而不包含文件夹。-
temp_monitor.py。应用程序逻辑。
-
greengrasssdk。发布 MQTT 消息的 Python Greengrass Lambda 函数所需的库。
此即您的 Lambda 函数部署软件包。
-
现在,创建一个使用部署程序包的 Lambda 函数。
第 5 步:在中创建 Lambda 函数Amazon Lambda控制台
在此步骤中,您将使用Amazon Lambda控制台创建 Lambda 函数并将其配置为使用您的部署程序包。接着,发布函数版本并创建别名。
-
首先,创建 Lambda 函数。
-
在 Amazon Web Services Management Console中,选择 Services (服务),然后打开 Amazon Lambda 控制台。
-
选择创建函数然后选择从头开始创作.
-
在 Basic information (基本信息) 部分中,使用以下值:
-
对于 Function name(函数名称),请输入
TempMonitor
。 -
对于 Runtime (运行时),选择 Python 3.7。
-
适用于Permissions (权限),请保留默认设置。这将创建一个授予基本 Lambda 权限的执行角色。此角色未由使用Amazon IoT Greengrass.
-
-
在页面底部,选择创建函数。
-
-
接下来,注册处理程序并上传您的 Lambda 函数部署程序包。
-
在存储库的代码选项卡,位于源代码,选择从以下项上传. 从下拉列表中,选择.zip 文件.
-
选择上传,然后选择您的
temp_monitor_python.zip
部署程序包。然后,选择 Save (保存)。 -
在存储库的代码函数的选项卡,位于运行时设置,选择编辑,然后输入以下值。
-
对于 Runtime (运行时),选择 Python 3.7。
-
对于 Handler (处理程序),输入
temp_monitor.function_handler
。
-
-
选择Save(保存)。
注意
这些区域有:测试的按钮Amazon Lambda控制台不使用此函数。这些区域有:Amazon IoT Greengrass核心开发工具包不包含在Amazon Lambda控制台。这些模块(例如
greengrass_common
) 将在函数部署到你的 Greengrass 核心后提供给这些函数。
-
-
现在,发布您的 Lambda 函数的第一个版本并创建版本的别名.
注意
Greengrass 组可以按别名(推荐)或版本引用 Lambda 函数。使用别名,您可以更轻松地管理代码更新,因为函数代码更新后,您无需更改订阅表或组定义。相反,您只需将别名指向新函数版本。
-
在存储库的TempMonitor:1配置页面,来自操作” 菜单,选择创建别名.
-
在创建新别名页面上,使用以下值:
-
对于 Name (名称),请输入
GG_TempMonitor
。 -
对于 Version (版本),选择 1。
注意
Amazon IoT Greengrass不支持 Lambda 别名$LATEST版本。
-
-
选择Create(创建)。
-
现在,您已准备就绪,可以将 Lambda 函数添加到 Greengrass 组。
第 6 步:将一个 Lambda 函数添加到 Greengrass 组
在该步骤中,您将 Lambda 函数添加到该组,然后配置其生命周期和环境变量。有关更多信息,请参阅 使用组特定的配置控制 Greengrass Lambda 函数的执行。
-
在组配置页面上,选择Lambda 函数” 选项卡。
-
UNDER我的 Lambda 函数,选择Add.
-
在存储库的添加 Lambda 函数页面,选择TempMonitor用于您的 Lambda 函数。
-
适用于Lambda 函数版本,选择别名:GG_TempMonitor.
-
选择添加 Lambda 函数.
步骤 7:将订阅添加到 Greengrass 组
在该步骤中,您将添加一个订阅,使 Lambda 函数将输入数据发送到连接器。此连接器定义它订阅的 MQTT 主题,因此该订阅使用其中一个主题。这与示例函数发布到的主题相同。
对于本教程,您还可以创建订阅,以允许函数从 Amazon IoT 接收模拟温度读数,并允许 Amazon IoT 从连接器接收状态信息。
-
在存储库的创建订阅页面上,配置源和目标,如下所示:
-
适用于源类型,选择Lambda 函数,然后选择TempMonitor.
-
适用于Target type,选择连接器,然后选择Twilio 通知.
-
-
对于主题筛选条件,选择
twilio/txt
. -
选择 Create subscription(创建订阅)。
-
重复步骤 1 至 4,以创建允许 Amazon IoT 将消息发布到该函数的订阅。
-
适用于源类型,选择服务,然后选择IoT 云.
-
适用于选择一个目标,选择Lambda 函数,然后选择TempMonitor.
-
对于 Topic filter (主题筛选条件),输入
temperature/input
。
-
-
重复步骤 1 至 4,以创建允许连接器将消息发布到 Amazon IoT 的订阅。
-
适用于源类型,选择连接器,然后选择Twilio 通知.
-
适用于Target type,选择服务,然后选择IoT 云.
-
对于主题筛选条件,已为您输入
twilio/message/status
。这是连接器发布到的预定义主题。
-
步骤 8:部署 Greengrass 组
将组部署到核心设备。
注意
Greengrass 组每次只能包含一个连接器版本。有关升级连接器版本的信息,请参阅升级连接器版本。
测试解决方案
-
在存储库的Amazon IoT控制台主页,选择测试.
-
适用于订阅主题,使用以下值,然后选择订阅. Twilio 通知连接器向此主题发布状态信息。
属性
值
订阅主题
twilio/message/status
MQTT 负载显示
将负载显示为字符串
-
适用于向主题发布,使用以下值,然后选择发布调用函数。
属性
值
主题
temperature/input
消息
Replace
收件人姓名
有名字和recipient-phone-number
使用文本消息收件人的电话号码。示例:+12345000000
{ "to_name": "
recipient-name
", "to_number": "recipient-phone-number
", "temperature": 31 }如果您使用的是试用账户,则必须将非 Twilio 收款人的电话号码添加到已验证的电话号码列表中。有关更多信息,请参阅 。验证您的个人电话号码
. 如果成功,收件人会收到短信,控制台会显示
success
状态来自输出数据.现在,将输入消息中的
temperature
更改为29
并发布。由于温度小于 30,因此 TempMonitor 函数不会触发 Twilio 消息。