测试通信 (禁用了设备同步) - Amazon IoT Greengrass
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅中国的 Amazon Web Services 服务入门

Amazon IoT Greengrass Version 1在 2023 年 6 月 30 日之前,不再接收功能更新,只会收到安全补丁和错误修复。有关更多信息,请参阅 。Amazon IoT Greengrass V1维护政策. 强烈建议您迁移到Amazon IoT Greengrass Version 2,它补充说重要新功能对其他平台的支持.

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

测试通信 (禁用了设备同步)

  1. 确保您的计算机和Amazon IoT Greengrass核心设备已使用同一个网络连接到 Internet。

    1. 在存储库的Amazon IoT Greengrass核心设备,运行以下命令以查找其 IP 地址。

      hostname -I
    2. 在计算机上,使用核心的 IP 地址运行以下命令。可以使用 Ctrl + C 停止 ping 命令。

      ping IP-address

      类似于下面的输出指示了计算机与Amazon IoT Greengrass核心设备(0% 数据包丢失):

      
                        成功的 ping 命令输出。
      注意

      如果您无法对正在运行 Amazon IoT Greengrass 的 EC2 实例进行 ping 操作,请确保该实例的入站安全组规则允许 ICMP 流量用于回显请求消息。有关更多信息,请参阅 。在安全组中添加规则中的适用于 Linux 实例的Amazon EC2 用户指南.

      在 Windows 主机上,在具有高级安全性应用程序的 Windows 防火墙中,您可能还需要启用一个允许入站回显请求的入站规则(例如,File and Printer Sharing (Echo Request - ICMPv4-In) (文件和打印机共享 (回显请求 - ICMPv4-In))),或创建一个。

  2. 获取您的 Amazon IoT 终端节点。

    1. Amazon IoT控制台导航窗格中,选择设置.

    2. UNDER设备数据终端节点,记下的值端点. 您可以使用此值在以下步骤中替换命令中的 AWS_IOT_ENDPOINT 占位符。

  3. 在您的计算机上(不是Amazon IoT Greengrass核心设备),打开两个命令行(终端或命令提示符)窗口。一个窗口代表 G_Switch 客户端设备,另一个窗口代表 G_Switch 客户端设备TrafficLight 客户端设备。

    1. 从 G_Switch 客户端设备窗口中,运行以下命令。

      • Replacepath-to-certs-folder包含证书、密钥和 Python 文件的文件夹的路径。

      • AWS_IOT_ENDPOINT 替换为您的终端节点。

      • 替换两个switchCertId实例,您的 G_Switch 客户端设备的文件名中包含证书 ID。

      cd path-to-certs-folder python lightController.py --endpoint AWS_IOT_ENDPOINT --rootCA AmazonRootCA1.pem --cert switchCertId-certificate.pem.crt --key switchCertId-private.pem.key --thingName GG_TrafficLight --clientId GG_Switch
    2. 来自 GG_TrafficLight 客户端设备窗口中,运行以下命令。

      • Replacepath-to-certs-folder包含证书、密钥和 Python 文件的文件夹的路径。

      • AWS_IOT_ENDPOINT 替换为您的终端节点。

      • 替换两个lightCertId在您的 GG_ 的文件名中包含证书 ID 的实例TrafficLight 客户端设备。

      cd path-to-certs-folder python trafficLight.py --endpoint AWS_IOT_ENDPOINT --rootCA AmazonRootCA1.pem --cert lightCertId-certificate.pem.crt --key lightCertId-private.pem.key --thingName GG_TrafficLight --clientId GG_TrafficLight

      每隔 20 秒,开关会将影子状态更新为 G、Y 和 R,并且灯会显示新状态,如下文所示。

      GG_Switch 输出:

      
                                    与 GG_Switch 相关联的输出的屏幕截图。

      GG_TrafficLight 输出:

      
                                    与 G_相关联的输出的屏幕截图TrafficLight.

    在首次执行时,每个客户端设备脚本都将运行Amazon IoT Greengrass发现服务以连接到Amazon IoT Greengrass核心(通过互联网)。在客户端设备发现了并成功连接到Amazon IoT Greengrasscore,future 操作可以在本地执行。

    注意

    lightController.pytrafficLight.py 脚本将连接信息存储在 groupCA 文件夹中,该文件夹与脚本在同一文件夹中创建。如果您收到连接错误,确保在ggc-host文件与核心的 IP 地址终端节点匹配。

  4. 在Amazon IoT控制台,选择您的Amazon IoT Greengrass组,选择客户端设备选项卡,然后选择GG_TrafficLight打开客户端设备的Amazon IoT“事物详细信息” 页面。

  5. 选择设备影子选项卡。在 G_Switch 更改状态后,不应对该影子进行任何更新。那是因为 GG_TrafficLight 设置为禁用与云端的影子同步.

  6. Ctrl+C在 G_Switch (lightController.py) 客户端设备窗口。你应该看到 GG_TrafficLight (trafficLight.py) 窗口停止接收状态更改消息。

    保持这些窗口打开,以便您可以在下一部分中运行这些命令。