我正在尝试记录来自http客户端的原始请求/响应。
我正在从这些logging instructions关注log4j2配置。
HttpAsync客户端依赖性:-httpasyncclient(版本4.1.1)
log4j2.xml

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN">
<Appenders>
    <RollingRandomAccessFile name="app-log" fileName="${log.path}/app.log"
                             filePattern="${log.path}/app-%d{yyyy-MM-dd}.gz">
        <PatternLayout>
            <pattern>[%-5level] [%X{uuid}] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n</pattern>
        </PatternLayout>
        <Policies>
            <TimeBasedTriggeringPolicy interval="1" modulate="true"/>
        </Policies>
    </RollingRandomAccessFile>
</Appenders>
<Loggers>
    <AsyncLogger name="org.apache.http.impl.conn.Wire" level="debug">
        <AppenderRef ref="app-log"/>
    </AsyncLogger>
    <AsyncRoot level="debug" includeLocation="true">
        <AppenderRef ref="app-log"/>
    </AsyncRoot>
</Loggers>
</Configuration>
可以正常打印,但threadcontext没有传递到记录仪上。
例子:-
// with uuid, output of logger.debug(ThreadContext.getImmutableContext().toString());

[DEBUG] [c48b97f7-0094-44af-82af-3d6b43d76014] 2016-11-14 17:06:03.408 [http-bio-8080-exec-1] OutboundRequestHandler - {uuid=c48b97f7-0094-44af-82af-3d6b43d76014}

// without uuid
[DEBUG] [] 2016-11-14 17:06:03.440 [I/O dispatcher 1] headers - http-outgoing-0 >> POST /abcd.json HTTP/1.1
[DEBUG] [] 2016-11-14 17:06:03.441 [I/O dispatcher 1] headers - http-outgoing-0 >> Content-Length: 2
[DEBUG] [] 2016-11-14 17:06:03.441 [I/O dispatcher 1] headers - http-outgoing-0 >> Content-Type: text/plain; charset=ISO-8859-1
[DEBUG] [] 2016-11-14 17:06:03.441 [I/O dispatcher 1] headers - http-outgoing-0 >> Host: 127.0.0.1:80
[DEBUG] [] 2016-11-14 17:06:03.441 [I/O dispatcher 1] headers - http-outgoing-0 >> Connection: Keep-Alive
[DEBUG] [] 2016-11-14 17:06:03.441 [I/O dispatcher 1] headers - http-outgoing-0 >> User-Agent: Apache-HttpAsyncClient/4.1.1 (Java/1.8.0_92)
如何将ThreadContext传递给记录器?
谢谢。

最佳答案

由于设置UUID的线程(http-bio-8080-exec-1)与正在执行日志记录的应用程序中的线程(I / O调度程序1)不同,因此它们具有不同的ThreadContext映射,第二个线程不能查看第一线程在其映射中放置了什么。

从log4j 2.7开始,可以创建一个custom context data injector,它可以从ThreadLocal映射之外的其他位置获取上下文数据(因为这本质上就是ThreadContext的含义)。

这确实意味着您需要创建一个自定义外观,类似于log4j的ThreadContext,在该外观中将键值对放入某种数据结构中。我不熟悉AsyncHttpClient,但是找不到“上下文”概念,该概念允许单独的线程共享与同一会话关联的数据。

您的自定义context injector implementation将获取键值对的快照,并将其注入到每个日志消息的LogEvent中。

09-04 11:46