0

根据有关记录 AWSRequestId 的本指南,我可以添加%X{AWSRequestId}我的 logback.xml 以在我的 lambda 函数上打印请求 ID。在示例中,在 MDC 上添加此键的方法是populateMappingDiagnosticContextValuesclass MicronautRequestHandler。但是由于我的 lambda 函数有两个端点,所以我将它创建为 Application 类型,并且它说它使用MicronautLambdaHandler作为处理程序类。 指导

我所做的是创建了扩展MicronautLambdaHandler并添加了populateMappingDiagnosticContextValues方法的自定义处理程序。

@Override
public AwsProxyResponse handleRequest(AwsProxyRequest input, Context context) {
    if (context != null) {
        populateMappingDiagnosticContextValues(context);
    }
    return handler.proxy(input, context);
}

logback.xml

<configuration>
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <withJansi>false</withJansi>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss} %X{AWSRequestId} %-5p %c{1} - %m%n</pattern>
        </encoder>
    </appender>
    <root level="info">
        <appender-ref ref="STDOUT" />
    </root>
</configuration>

在 lambda 设置中,我将处理程序指向了我的自定义处理程序,并且应用程序正在运行。除了日志没有显示 AWSRequestId。此功能是否仅适用于MicronautRequestHandler课堂而不适用于MicronautLambdaHandler

我还尝试了使用 log4j2 记录请求 ID的 aws指南。但是在构建 GraalVM 原生镜像时 log4j 不起作用,这就是我坚持使用 logback 的原因。

4

1 回答 1

0

如果您复制populateMappingDiagnosticContextValuesmdcput进入您的处理程序(我想您做到了),它应该可以在没有任何额外更改的情况下工作。

于 2022-02-23T08:19:12.417 回答