解析 CloudWatch 日志流的 AWS Lambda

AWS Lambda that parse CloudWatch log Stream

我正在编写一个 AWS Lambda 来处理来自 CloudWatch 的日志流。我在 Java 中实现它。我正在努力解决几个问题:

  1. 如何对接收到的日志进行解码解压。 在 Python 中,以下代码有效:
import json
import base64
import zlib

def stream_gzip_decompress(stream):
    dec = zlib.decompressobj(32 + zlib.MAX_WBITS)  # offset 32 to skip the header
    foo=''
    for chunk in stream:
        rv = dec.decompress(chunk)
        if rv:
            foo += rv
    return foo

def lambda_handler(event, context):
    # Decode and decompress the AWS Log stream to extract json object
    stream=json.dumps(event['awslogs']['data'])
    payload=json.loads(stream_gzip_decompress(stream.decode('base64')))
    print(payload)

如何在Java中实现类似的功能?

  1. 此外,当我尝试添加外部 jar org.json 来解析输入 JSON 数据时。尽管我尝试了 Whosebug
  2. 上给出的大部分内容,但我遇到了以下错误

错误:

{ "errorMessage": "Error loading class UpdateCurrentNotificationStatus: org/json/JSONException",
"errorType": "class java.lang.NoClassDefFoundError" }

以下是我正在编写的示例代码:

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;

import org.json.JSONException;
import org.json.JSONObject;

import com.amazonaws.services.lambda.runtime.RequestStreamHandler;
import com.amazonaws.services.lambda.runtime.Context; 

public class UpdateCurrentNotificationStatus implements RequestStreamHandler {
    public void handleRequest(InputStream inputStream, OutputStream outputStream, Context context)
            throws IOException {
        int letter;
        while((letter = inputStream.read()) != -1)
        {
            //outputStream.write(Character.toUpperCase(letter));
            JSONObject json = new JSONObject(letter);
            try {
              String stream = json.getString("awslogs");
              System.out.println(stream);
          } catch (JSONException e) {
              // TODO Auto-generated catch block
              e.printStackTrace();
          }
        }
    }
}

有人可以帮我解决这个问题吗?

谢谢,

普拉萨德

您需要做的是接受 CloudWatchLogsEvent 作为输入参数。

    public class Testing implements RequestHandler<CloudWatchLogsEvent, String> {


        public String handleRequest(CloudWatchLogsEvent request, Context context){
            context.getLogger().log(request.toString());
            String timeStamp = new SimpleDateFormat("yyyy-MM-dd_HH:mm:ss").format(Calendar.getInstance().getTime());
            context.getLogger().log("Invocation started: " + timeStamp);

            context.getLogger().log(request.toString());

            timeStamp = new SimpleDateFormat("yyyy-MM-dd_HH:mm:ss").format(Calendar.getInstance().getTime());
            context.getLogger().log("Invocation completed: " + timeStamp);
            return "completed";
        }
}

请记住,这也会打印经过 gzip 压缩的编码 base 64 字符串。您必须对其进行解码和解压缩。网上有关于如何做到这一点的示例,所以我不会深入研究。一个例子在这里 .