Jboss 记录器在线程生命周期中清除 MDC
Jboss logger clear MDC during thread lifecycle
我需要使用 jboss 记录器和 logstash 在 wildfly 上改进 JavaEE 应用程序 运行 的日志记录,我正在使用 MDC 来存储用户 ID,但由于我是线程使用的新手,所以我'我不知道如何在回收线程之前清除 MDC
我找到了清除 MDC 的不同方法,但我想我遗漏了一些关于线程的知识……:
我试过扩展线程:
public class MdcThread extends Thread {
LoggingTools loggingTools = new LoggingTools(MdcThread.class);
@Override
public void run() {
loggingTools.info("MdcThread");
MDC.clear();
}
}
我尝试扩展 ThreadPoolExecutor :
public class MdcThreadPoolExecutor extends ThreadPoolExecutor {
static LoggingTools loggingTools = new LoggingTools(MdcThreadPoolExecutor.class);
...constructors...
@Override
public void execute(Runnable command) {
super.execute(wrap(command));
}
public static Runnable wrap(final Runnable runnable) {
return new Runnable() {
@Override
public void run() {
try {
runnable.run();
} finally {
loggingTools.info("Mdc clear");
MDC.clear();
}
}
};
}
}
但是其中 none 被称为...所以我假设 ThreadPoolExecutor 是一种使用线程但不一定使用的方法?我怎样才能达到线程的生命周期?
编辑:
这是我使用的过滤器:
@WebFilter("/*")
public class MdcFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
// TODO Auto-generated method stub
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
if (request != null) {
//add what I want in MDC
}
chain.doFilter(request, response);
}
@Override
public void destroy() {
MDC.clear();
}
}
如果您正在使用 logback,那么 WildFly 或 JBoss 日志管理器将不会管理 MDC。 MDC 的大多数实现,我假设您正在使用 org.slf4j.MDC
,因为您正在使用 logback,它们是线程局部变量,因此 MDC.clear()
只会清除该线程 MDC 映射上的映射。看看 slf4j 的 MDC manual.
如果您想清除消息诊断上下文,您需要在添加要清除的数据的同一线程中执行此操作。
我需要使用 jboss 记录器和 logstash 在 wildfly 上改进 JavaEE 应用程序 运行 的日志记录,我正在使用 MDC 来存储用户 ID,但由于我是线程使用的新手,所以我'我不知道如何在回收线程之前清除 MDC
我找到了清除 MDC 的不同方法,但我想我遗漏了一些关于线程的知识……: 我试过扩展线程:
public class MdcThread extends Thread {
LoggingTools loggingTools = new LoggingTools(MdcThread.class);
@Override
public void run() {
loggingTools.info("MdcThread");
MDC.clear();
}
}
我尝试扩展 ThreadPoolExecutor :
public class MdcThreadPoolExecutor extends ThreadPoolExecutor {
static LoggingTools loggingTools = new LoggingTools(MdcThreadPoolExecutor.class);
...constructors...
@Override
public void execute(Runnable command) {
super.execute(wrap(command));
}
public static Runnable wrap(final Runnable runnable) {
return new Runnable() {
@Override
public void run() {
try {
runnable.run();
} finally {
loggingTools.info("Mdc clear");
MDC.clear();
}
}
};
}
}
但是其中 none 被称为...所以我假设 ThreadPoolExecutor 是一种使用线程但不一定使用的方法?我怎样才能达到线程的生命周期?
编辑: 这是我使用的过滤器:
@WebFilter("/*")
public class MdcFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
// TODO Auto-generated method stub
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
if (request != null) {
//add what I want in MDC
}
chain.doFilter(request, response);
}
@Override
public void destroy() {
MDC.clear();
}
}
如果您正在使用 logback,那么 WildFly 或 JBoss 日志管理器将不会管理 MDC。 MDC 的大多数实现,我假设您正在使用 org.slf4j.MDC
,因为您正在使用 logback,它们是线程局部变量,因此 MDC.clear()
只会清除该线程 MDC 映射上的映射。看看 slf4j 的 MDC manual.
如果您想清除消息诊断上下文,您需要在添加要清除的数据的同一线程中执行此操作。