Jboss logger очищает MDC в течение жизненного цикла потока - PullRequest
0 голосов
/ 17 мая 2019

Мне нужно улучшить ведение журнала в приложении 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();
    }

}

1 Ответ

0 голосов
/ 17 мая 2019

Если вы используете logback, тогда WildFly или JBoss Log Manager не будут управлять MDC. Большинство реализаций MDC, и я предполагаю, что вы используете org.slf4j.MDC, поскольку вы используете logback, являются локальными потоками, поэтому MDC.clear() только очистит карту на карте MDC этих потоков. Взгляните на руководство MDC slf4j .

Если вы хотите очистить контекст диагностики сообщений, вам нужно сделать это в том же потоке, который добавляет, что добавляет данные, которые вы хотите очистить.

...