AWS CloudWatch日志订阅过滤器解码

Kel*_*vin 4 decode node.js amazon-sns aws-lambda amazon-cloudwatchlogs

我正在使用CloudWatch日志订阅筛选器流到Lambda并将消息发布到SNS主题。但是它将输出乱码消息,并且无法成功解码。

我的输出:

k
%"
 jVbB
Run Code Online (Sandbox Code Playgroud)

如果不解码,将输出以下内容:

{ "awslogs": {"data": "BASE64ENCODED_GZIP_COMPRESSED_DATA"} }
Run Code Online (Sandbox Code Playgroud)

我的代码在下面,它使用的是nodejs:

console.log("Loading function");
var AWS = require("aws-sdk");

exports.handler = function(event, context) {
    var eventText = JSON.stringify(event, null, 2);
    var decodeText = new Buffer(eventText, 'base64').toString('ascii');
    console.log("Received event:", eventText);
    var sns = new AWS.SNS();
    var params = {
        Message: decodeText, 
        Subject: "Test SNS From Lambda",
        TopicArn: "arn:aws:sns:region:account:snsTopic"
    };
    sns.publish(params, context.done);
};
Run Code Online (Sandbox Code Playgroud)

jar*_*mod 8

CloudWatch Logs以gzip压缩和base64编码的列表形式交付给已订阅的Lambda函数。

这是如何解码和解压缩日志列表的示例:

const zlib = require('zlib');

exports.handler = async (event) => {
  if (event.awslogs && event.awslogs.data) {
    const payload = Buffer.from(event.awslogs.data, 'base64');

    const logevents = JSON.parse(zlib.unzipSync(payload).toString()).logEvents;

    for (const logevent of logevents) {
      const log = JSON.parse(logevent.message);
      console.log(log);
    }
  }
};
Run Code Online (Sandbox Code Playgroud)