Я использую Wildfly 24.0.1, и у меня много приложений, работающих в одной группе серверов, обычные военные приложения и изменение уровня журнала с помощью консоли wildfly работают, как и ожидалось. Когда я получаю доступ к консоли wildfly => конфигурация => профили => ведение журнала => категории и меняю в любое время, и это работает. Однако, когда я развертываю приложение SpringBoot и пытаюсь изменить любой уровень журнала приложения, он обновляет конфигурацию, но продолжает регистрировать последнюю конфигурацию, например: это был уровень ведения журнала INFO, я развертываю приложение Springboot, а затем меняю уровень журнала на ОШИБКА. Он продолжает регистрировать уровень INFO.
Я попытался удалить все библиотеки журналов из моего приложения Springboot, изменить файл структуры jboss, даже обновить версию Springboot, но ничего не работает.
Следуя моему файлу pom springboot:
<project xmlns = "http://maven.apache.org/POM/4.0.0"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>group.id</groupId>
<artifactId>project-name</artifactId>
<version>1.0.0</version>
<name>project-name</name>
<packaging>war</packaging>
<description></description>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<java.version>1.8</java.version>
<!-- Compatibility Wildfly (OVERRIDE SPRINGBOOT) -->
<classmate.version>1.4.0</classmate.version>
<jackson-bom.version>2.9.9.20190807</jackson-bom.version>
</properties>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.10.RELEASE</version>
<relativePath /> <!-- lookup parent from repository -->
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.amqp</groupId>
<artifactId>spring-rabbit-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
<!-- OUTRAS DEPENDENCIAS -->
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>mssql-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.reflections</groupId>
<artifactId>reflections</artifactId>
<version>0.10.2</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<profiles>
<profile>dev</profile>
<profile>prod</profile>
</profiles>
</configuration>
</plugin>
</plugins>
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
</build>
<profiles>
<profile>
<id>dev</id>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
<properties>
<spring.profiles.active>dev</spring.profiles.active>
</properties>
</profile>
<profile>
<id>prod</id>
<properties>
<spring.profiles.active>prod</spring.profiles.active>
</properties>
<!-- <DEPENDENCIES> required to work with wildfly -->
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
</profile>
</profiles>
</project>
jboss-deployment-structure.xml
<?xml version='1.0' encoding='UTF-8'?>
<jboss-deployment-structure
xmlns = "urn:jboss:deployment-structure:1.1">
<deployment>
</deployment>
</jboss-deployment-structure>
Проект работает, запускается, даже журналы правильные, но если я пытаюсь обновить уровень журнала во время выполнения, он не работает.
Зависимость, связанная с журналом? Потому что я удаляю их всех из своего приложения. Log4j, slf4, logback и такое еще бывает.
Извини, нет. Я имею в виду исключение из зависимостей Spring Boot. Если его включить в WAR, то он перешивает лог-менеджер. Я просто не помню, какая это зависимость.
да да, я понял, мне просто интересно, будет ли связанная с зависимостью спецификация с логами или что-то еще... Я поищу это
Я думаю, что org.slf4j:jul-to-slf4j
. Если вы видите это в своем mvn dependency:tree
, его нужно исключить из вашей ВОЙНЫ.
Через 2 дня протестировал 2 приложения Springboot и все заработало.
Мне не нужно было менять файл pom, он уже исключал библиотеку «spring-boot-starter-logging».
Чтобы заставить его работать, просто нужно добавить в «src/main/resources/» файл «logging.properties» следующим образом:
# Define default log level to OFF
.level=OFF
# deactivate org.springframework package logs
org.springframework.level=OFF
Похоже, Spring Boot что-то делает для изменения уровня журнала. Если я правильно помню, есть некоторая зависимость, которую необходимо исключить, поскольку она изменяет диспетчер журналов.