我使用 AWS API Gateway 作为 RESTful API 端点,然后将记录传递到 Kinesis 流,然后传递到 Lambda。但是,似乎有一些数据没有到达 Lambda 函数。
我一直在寻找一个例子或与我正在寻找的东西接近但没有运气的东西。
设备消息如下所示,可能有多个消息,因此它位于数组中。
[{
"deviceId": "00000000001",
"deviceType": "device",
"receivedTs": 1539234374000,
"readingList": [{
"channelId": 13,
"type": "temperature",
"value": 25.3,
"unit": "°C"
},{
"channelId": 12,
"type": "humidity",
"value": 3.65,
"unit": "V",
"label": "primary-battery"
}]
}]
我目前拥有的传出映射模板如下:
{
"StreamName": "my-stream",
"Records": [
#foreach($elem in $input.path('$'))
#set($event = "{
""deviceId"": $elem.deviceId
""deviceType"": $elem.deviceType,
""receivedTs"": $elem.receivedTs,
""readingList"": [
#foreach($reading in $elem.readingList)
{
""channelId"": $reading.channelId,
""type"": ""$reading.type"",
""value"": $reading.value,
""unit"": ""$reading.unit"",
""label"": ""$reading.label""
}]
#if($foreach.hasNext),#end
#end
}")
{
"Data": "$util.base64Encode($event)",
"PartitionKey": "$elem.deviceType"
}#if($foreach.hasNext),#end
#end
]
}
下面是我的 CloudWatch 日志从 lambda 函数中的处理过程中显示的内容。正在显示一些数据,但对象的 readingList 数组未正确填写,它只是显示为空。我有一种感觉,这与映射模板中的 foreach 循环有关,但我似乎无法弄清楚是什么。
Beginning to process all 1 records...
Event Name: aws:kinesis:record
Getting record contents.
Record contents: {
"deviceId": "00000000001",
"deviceType": "device",
"receivedTs": "1539234374000",
"readingList": [{
"channelId": "",
"type": "",
"value": "",
"unit": "",
"label": ""
}]
}
lambda 函数没有什么特别之处。对于测试,它只是使用 AWS 提供的示例代码将消息内容写入控制台。
如果有人有任何想法或一些有用的链接,将不胜感激。感谢您的时间。