Spring boot 2 и logback MDC с реактором

У меня есть приложение, написанное с помощью пружины 5 и реактора. Я помещаю в контекст подписчика некоторую информацию, такую ​​как идентификатор пользователя. Теперь я хочу зарегистрировать этот идентификатор пользователя. Я пытаюсь использовать MDC, но если запрос меняет поток, я потерял информацию. Как я могу решить этот вопрос? Есть ли способ настроить MDC, чтобы во всех журналах приложения, включая внешнюю библиотеку, были данные, которые я ввел с использованием контекста подписчика? Я уже пробовал то, что описано здесь, но работает нормально, но не решает мою проблему с журналами внешней библиотеки.

https://simonbasle.github.io/2018/02/contextual-logging-with-reactor-context-and-mdc/

взгляните на эту статью из двух частей ndportmann.com/logging-with-context-in-spring-webflux

Serhii Povísenko 26.09.2019 16:26
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Версия Java на основе версии загрузки
Версия Java на основе версии загрузки
Если вы зайдете на официальный сайт Spring Boot , там представлен start.spring.io , который упрощает создание проектов Spring Boot, как показано ниже.
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
5
1
1 584
1

Ответы 1

Весенний облачный сыщик предлагает решение для этого

Вам нужно добавить в проект зависимость Spring Cloud Sleuth

Чтобы добавить настраиваемое свойство в контекст сыщика, используйте

MDC.put("userId", userId);
ExtraFieldPropagation.set("userId", userId);

здесь "userId" - это ключ, который используется для распространения значения

Чтобы распространять ключ userId при изменении потоков, используйте

spring.sleuth.propagation-keys=userId
spring.sleuth.log.slf4j.whitelisted-mdc-keys=userId

Вы можете получить доступ к ключу userId из входа в систему, используя

<appender name = "CONSOLE" class = "ch.qos.logback.core.ConsoleAppender"> 
  <layout>
    <Pattern>%X{userId} - %m%n</Pattern>
  </layout> 
</appender>

Другие вопросы по теме