我创建了一个AWS IoT规则。当客户端向terminal1/
主题发送消息时,它会触发Lambda函数(客户端使用从AWS IoT生成的证书文件向terminal1/
发送消息。)。我需要一个Lambda函数来使用客户端消息生成新消息并发送到另一个主题(terminal2/test
)。
我尝试触发“将消息重新发布到AWS IoT主题”。但是,它会将数据发送到特定主题。它只是转发相同的消息(我需要发送不同的消息)。
我创建了一个Lambda函数来向另一个主题发送消息。但我无法验证端点。
这是我创建的Lambda函数(根据this),
'use strict';
// Load the AWS SDK
var AWS = require("aws-sdk");
exports.handler = (event, context, callback) => {
var iotdata = new AWS.IotData({
endpoint: 'akugdx70brb.iot.us-west-2.amazonaws.com:8883',
apiVersion: '2015-05-28'
});
var params = {
topic: 'terminal2/test/',
payload: new Buffer('...') || 'STRING_VALUE',
qos:1
};
iotdata.publish(params, function(err, data) {
if (err) console.log(err, err.stack); // an error occurred
else console.log(data); // successful response
});
};
它会生成此错误,
2018-05-01T06:22:02.394Z f5a570ef-4d07-11e8-b8a2-6bad8f2982f7 { Error: write EPROTO 139935652661056:error:14094412:SSL routines:ssl3_read_bytes:sslv3 alert bad certificate:../deps/openssl/openssl/ssl/s3_pkt.c:1493:SSL alert number 42
139935652661056:error:1409E0E5:SSL routines:ssl3_write_bytes:ssl handshake failure:../deps/openssl/openssl/ssl/s3_pkt.c:659:
at exports._errnoException (util.js:1018:11)
at WriteWrap.afterWrite (net.js:800:14)
message: 'write EPROTO 139935652661056:error:14094412:SSL routines:ssl3_read_bytes:sslv3 alert bad certificate:../deps/openssl/openssl/ssl/s3_pkt.c:1493:SSL alert number 42\n139935652661056:error:1409E0E5:SSL routines:ssl3_write_bytes:ssl handshake failure:../deps/openssl/openssl/ssl/s3_pkt.c:659:\n',
code: 'NetworkingError',
errno: 'EPROTO',
syscall: 'write',
region: 'us-west-2',
hostname: 'akugdx70brb.iot.us-west-2.amazonaws.com',
retryable: true,
time: 2018-05-01T06:22:02.394Z } 'Error: write EPROTO 139935652661056:error:14094412:SSL routines:ssl3_read_bytes:sslv3 alert bad certificate:../deps/openssl/openssl/ssl/s3_pkt.c:1493:SSL alert number 42\n139935652661056:error:1409E0E5:SSL routines:ssl3_write_bytes:ssl handshake failure:../deps/openssl/openssl/ssl/s3_pkt.c:659:\n\n at exports._errnoException (util.js:1018:11)\n at WriteWrap.afterWrite (net.js:800:14)'
我想这意味着我无法验证主机,我在创建Lambda函数时没有使用任何证书。如何使用AWS Lambda将MQTT消息发送到同一主机,但发送到不同的主题? (上述Lambda函数在客户端发送消息时触发,我是否必须重新验证服务器以将消息发送到其他主题?)
答案 0 :(得分:0)
尝试使用
AWS.config.update({
accessKeyId: <accessKeyId>,
secretAccessKey: <secretAccessKey>,
region: <region>
});
答案 1 :(得分:0)
根据您要生成的内容,您可以使用主题规则本身转换输入消息,并跳过对lambda调用的收费。有关示例,请参阅https://docs.aws.amazon.com/iot/latest/developerguide/iot-substitution-templates.html。
答案 2 :(得分:0)
您的lambda应该使用可以访问IoT策略的角色。您的lambda执行角色没有足够的权限来编写或连接并发布到IoT。