如何使用 IoT 规则将数据从 AWS IoT 发送到 AWS DynamoDB v2

Abh*_* Bh 1 amazon-web-services amazon-dynamodb amazon-iam aws-iot

我想将各个数据值发送到从 AWS IoT 接收到的各个列到 AWS DynamoDB。

我的设备发送此有效负载:

    {
    "state": {
    "desired": {
        "DeviceId" : "Device101",
        "DateTime" : now,
        "Room1 Temperature" : m_t,
        "Room2 Temperature": b_t
        },
    "reported": {
        "Item": {
            "DeviceId" : "Device101",
            "DateTime" : now,
            "Room1 Temperature" : m_t,
            "Room2 Temperature": b_t
            }
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

我在此处的 Shadow Link 上收到此有效负载作为 Shadow Update:

$aws/东西/影子/更新

我创建了一个示例 DynamoDB 表并将其与 AWS IoT 规则相关联,以便每当数据传入上述主题时,它都会由 SQL 查询触发:

SELECT * FROM '$aws/things/shadow/update'

  • 此数据反映在我的影子更新中
  • 此数据不会转发到 DynamoDB 表
  • 问题是什么?!

任何帮助,将不胜感激。谢谢。

Jam*_*s G 5

首先,启用 Cloudwatch Logs 应该可以帮助您调试此问题。

通常,这些类型的静默故障表明您没有正确格式化数据以插入 DynamoDB。

检查事项:

  • 您的 SELECT 语句将不起作用,因为它需要拉入您要插入的内容。在您的情况下,这将是 SELECT 期望的。* 或 SELECT 报告。项目。*
  • 主分区键必须是您拉入的键之一,否则您的 DynamoDB 插入将失败。你的主分区键是什么?确保在 SELECT 语句的键列表中包含它
  • 确保您的主分区键的数据类型与您传入的类型相匹配 - 例如,如果您的主分区键是 DeviceId,则它应该是字符串类型(例如,不是整数)

CloudWatch 日志将提供更详细的信息来帮助您。有关如何执行此操作的信息,请参阅http://docs.aws.amazon.com/iot/latest/developerguide/cloud-watch-logs.html

您还可以通过从左侧导航中选择设置(齿轮)并更新日志记录下的设置,从 IoT 控制台启用它。