Мне нужно улучшить ведение журнала в приложении JavaEE, работающем на wildfly, с использованием jboss logger & logstash, я использую MDC для хранения идентификатора пользователя, но поскольку я новичок в использовании потоков, я не понимаю, как очистить 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();
}
}
};
}
}
Но ни один из них не называется ... Итак, я предполагаю, что 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();
}
}