根据有关记录 AWSRequestId 的本指南,我可以添加%X{AWSRequestId}
我的 logback.xml 以在我的 lambda 函数上打印请求 ID。在示例中,在 MDC 上添加此键的方法是populateMappingDiagnosticContextValues
class 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 的原因。