Среда выполнения уровня журнала изменений Wildfly перестает работать при развертывании приложения springboot

Я использую 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>

Проект работает, запускается, даже журналы правильные, но если я пытаюсь обновить уровень журнала во время выполнения, он не работает.

Похоже, Spring Boot что-то делает для изменения уровня журнала. Если я правильно помню, есть некоторая зависимость, которую необходимо исключить, поскольку она изменяет диспетчер журналов.

James R. Perkins 12.04.2023 22:20

Зависимость, связанная с журналом? Потому что я удаляю их всех из своего приложения. Log4j, slf4, logback и такое еще бывает.

Victor Bello 12.04.2023 22:38

Извини, нет. Я имею в виду исключение из зависимостей Spring Boot. Если его включить в WAR, то он перешивает лог-менеджер. Я просто не помню, какая это зависимость.

James R. Perkins 13.04.2023 02:53

да да, я понял, мне просто интересно, будет ли связанная с зависимостью спецификация с логами или что-то еще... Я поищу это

Victor Bello 13.04.2023 17:14

Я думаю, что org.slf4j:jul-to-slf4j. Если вы видите это в своем mvn dependency:tree, его нужно исключить из вашей ВОЙНЫ.

James R. Perkins 13.04.2023 22:19
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
0
5
70
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Через 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

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