使用触发的Lambda函数将MQTT消息发送到另一个IoT主题?

时间:2018-05-01 06:48:06

标签: amazon-web-services aws-lambda aws-iot

我创建了一个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函数在客户端发送消息时触发,我是否必须重新验证服务器以将消息发送到其他主题?)

3 个答案:

答案 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。