Я пытаюсь иметь несколько файлов журнала для моего весеннего загрузочного приложения. Я настроил файл logback.xml. Я могу добавить запрос данных весеннего спящего режима в свой файл журнала. Но когда я попытался добавить журнал запросов elasticsearch в свой файл журнала, созданный репозиторием spring-data-elasticsearch, я не получил никакого журнала в файле. Я добавил это в свой файл logback.xml:
<configuration>
<property name="LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger{40}.%M - %msg%n" />
<property name="APP_LOG_ROOT" value="/mylog/log"/>
<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>${LOG_PATTERN}</pattern>
</encoder>
</appender>
<appender name="applicationLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${APP_LOG_ROOT}/application.log</file>
<encoder>
<pattern>${LOG_PATTERN}</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${APP_LOG_ROOT}/application.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<timeBasedFileNamingAndTriggeringPolicy
class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>5MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
<maxHistory>30</maxHistory>
</rollingPolicy>
</appender>
<appender name="hibernateLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${APP_LOG_ROOT}/hibernate.log</file>
<encoder>
<pattern>${LOG_PATTERN}</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${APP_LOG_ROOT}/hibernate.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<timeBasedFileNamingAndTriggeringPolicy
class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>5MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
<maxHistory>30</maxHistory>
</rollingPolicy>
</appender>
<appender name="databaseLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${APP_LOG_ROOT}/database.log</file>
<encoder>
<pattern>${LOG_PATTERN}</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${APP_LOG_ROOT}/database.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<timeBasedFileNamingAndTriggeringPolicy
class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>5MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
<maxHistory>30</maxHistory>
</rollingPolicy>
</appender>
<!--<logger name="org.hibernate.type.descriptor.sql" level="trace">-->
<logger name="org.hibernate.SQL" level="trace" additivity="false">
<appender-ref ref="hibernateLog" />
</logger>
<logger name="org.springframework.data.elasticsearch.client.WIRE" level="trace">
<appender-ref ref="databaseLog" />
<appender-ref ref="console" />
</logger>
<logger name="com.test" level="info">
<appender-ref ref="applicationLog" />
<!--<appender-ref ref="console" />-->
</logger>
<root level="info">
<appender-ref ref="console" />
</root>
</configuration>
Я также пробовал здесь
<logger name="org.springframework.data.elasticsearch.core.*" level="debug" additivity="false">
<appender-ref ref="databaseLog" />
<appender-ref ref="console" />
</logger>
Но оба не работали. Как это решить? Я не хочу задавать их из файла свойств, так как не знаю, как настроить ведение журнала для нескольких файлов из файла .properties
Другой вопрос: если я несколько раз ссылаюсь на один и тот же log-appender для нескольких пакетов, будет ли это любая проблема?