Приложения Spring Boot инициализируют логирование минимум 3 раза. Первый - в SpringApplication, когда он создает регистратор, что происходит буквально в первую очередь. Если вы используете Log4j 2, это заставит его использовать свой обычный механизм для поиска файла log4j2. xml, log4j2.properties или log4j2.yml. Spring boot предоставляет конфигурацию по умолчанию, но, как вы знаете, вы можете изменить ее. Если вы это сделаете, вы можете указать регистратор root как
<Root level="${sys:root_log_level:-INFO}">
...
</Root>
Это позволит вам использовать -Droot_log_level=DEBUG
в командной строке. Если системное свойство не настроено, по умолчанию будет использоваться значение INFO.
Обратите внимание, что вы также можете указать альтернативное расположение для конфигурации ведения журнала: a) указав расположение файла в bootstrap .yml как * 1007. *
logging:
config: log4j2-myapp.xml
, а затем б) в файле с именем log4j2.application.properties как
log4j.configurationFile=log4j-mmyapp.xml
. Это приведет к тому, что при каждой перенастройке Log4j будет использоваться одна и та же конфигурация, включая начальную конфигурацию. Вы можете увидеть пример этого в Log4j пример приложения Spring Boot , где он извлекает конфигурацию ведения журнала из Spring Cloud Config.
Конечно, вы можете использовать механизм Spring для установки уровня ведения журнала, но это не повлияет на настройку журналирования в первый раз, поскольку Spring на тот момент ничего не сделал.
Я также должен указать, что Log4j поставляется с SpringLookup , который можно использовать в Spring приложения для ссылки на переменные конфигурации Spring в конфигурации log4j. Конечно, переменные не будут иметь значения при первой настройке журналирования, поскольку среда Spring не будет создана