Установка logging.level для отладки не отображает всю информацию - PullRequest
0 голосов
/ 07 мая 2020

Я очень новичок в Spring Framework и, чтобы понять, как все работает, пытался использовать logging.level как установленный для отладки, но в моем случае он не отображает всю информацию. Он показывает только создание одноэлементных компонентов области видимости, а не показывает прототипы компонентов. Когда я использую автоматическое подключение, теперь он показывает, что некоторый компонент автоматически подключается по имени или чему-то еще. Я перепробовал все, но не смог решить эту проблему. Пожалуйста, помогите мне. Заранее спасибо.

Это мой файл pom. xml.

    <?xml version="1.0" encoding="UTF-8"?>
    <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>
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.2.6.RELEASE</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
        <groupId>com.in28minutes.spring.basics</groupId>
        <artifactId>spring-in-5-steps</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <name>spring-in-5-steps</name>
        <description>Demo project for Spring Boot</description>

        <properties>
            <java.version>1.8</java.version>
        </properties>

        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
                <exclusions>
                        <exclusion>
                            <groupId>org.springframework.boot</groupId>
                            <artifactId>spring-boot-starter-logging</artifactId>
                        </exclusion>
                    </exclusions>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
                <exclusions>
                    <exclusion>
                        <groupId>org.junit.vintage</groupId>
                        <artifactId>junit-vintage-engine</artifactId>
                    </exclusion>
                </exclusions>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-devtools</artifactId>
            </dependency>
        </dependencies>

        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>

    </project>

Я использую здесь PROTOTYPE SCOPE

    package com.in28minutes.spring.basics.springin5steps;

    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.beans.factory.annotation.Qualifier;
    import org.springframework.beans.factory.config.ConfigurableBeanFactory;
    import org.springframework.context.annotation.Scope;
    import org.springframework.stereotype.Component;

    @Component
    @Scope(ConfigurableBeanFactory.SCOPE_PROTOTYPE)
    public class BinarySearchImpl {

        @Autowired
        private SortAlgorithm quickSortAlgorithm;

        public int binarySearch(int[] numbers, int numberToSearchFor) {

            int[] sortedNumbers = quickSortAlgorithm.sort(numbers);
            int n = sortedNumbers.length;
            for(int i=0;i<n;i++)
            System.out.println(sortedNumbers[i]);
            System.out.println(quickSortAlgorithm);
            // Search the array
            return 3;
        }

    }

Функция QuickSortAlgorithm, которую я использую using.

    package com.in28minutes.spring.basics.springin5steps;

    import org.springframework.stereotype.Component;

    @Component
    public class QuickSortAlgorithm implements SortAlgorithm {
        public int[] sort(int[] numbers) {
            // Logic for Quick Sort
            System.out.println("from Quick Sort");
            return numbers;
        }
    }

Интерфейс SortAlgorithm, который используется QuickSortAlgorithm.

    package com.in28minutes.spring.basics.springin5steps;

    public interface SortAlgorithm {
        public int[] sort(int[] numbers);
    }

Мой файл application.properties

    logging.level.org.springframework = DEBUG
    logging.level.com.howtodoinjava=DEBUG

    #output to a temp_folder/file
    logging.file.name=${java.io.tmpdir}/application.log

    # Logging pattern for the console
    logging.pattern.console= %d{yyyy-MM-dd HH:mm:ss} - %msg%n

    # Logging pattern for file
    logging.pattern.file= %d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%
...