slf4j не входит в DEBUG.log с помощью log.debug (...) - PullRequest
0 голосов
/ 29 августа 2018

У меня проблема с slf4j, регистрация на уровне информации и предупреждений работает. Но регистрация на уровне отладки не делает. Я проверил в отладчике, и log.isDebugEnabled () имеет значение true, поэтому log.debug ("INPUT: \ n" + input) выполняется, но DEBUG.log пуст. Я включил в своей IntelliJ IDE опцию «Включить вывод отладки» (она добавляет опцию VM -Ddebug), и она все еще не работает.

(..)
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
(..)
public class LoginController {

    private static final Logger log = LoggerFactory.getLogger(LoginController.class);

    public AuthUser login(InputStream inputStream, HttpServletRequest    request) throws Exception {

      final String input = misc.InputStreamToString(inputStream);
      if (log.isDebugEnabled()) {
        log.debug("INPUT:\n" + input);
     }

     (..)
   }

Обновление 1:

файл ресурсов / logback.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration>

<property name="HOME" value="${user.dir}/logs"/>

<appender name="FILE-INSERT-DEBUG"
          class="ch.qos.logback.core.rolling.RollingFileAppender">
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
        <level>DEBUG</level>
        <onMismatch>DENY</onMismatch>
    </filter>

    <file>${HOME}/DEBUG.log</file>
    <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
        <Pattern>
            %d{yyyy-MM-dd HH:mm:ss} - %msg%n
        </Pattern>
    </encoder>

    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <!-- rollover daily -->
        <fileNamePattern>${HOME}/archived/debug.%d{yyyy-MM-dd}.%i.log.zip
        </fileNamePattern>
        <timeBasedFileNamingAndTriggeringPolicy
                class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
            <maxFileSize>10MB</maxFileSize>
        </timeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>

</appender>

<appender name="FILE-INSERT-INFO"
          class="ch.qos.logback.core.rolling.RollingFileAppender">
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
        <level>INFO</level>
        <onMatch>ACCEPT</onMatch>
        <onMismatch>DENY</onMismatch>
    </filter>
    <file>${HOME}/INFO.log</file>
    <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
        <Pattern>
            %d{yyyy-MM-dd HH:mm:ss} - %msg%n
        </Pattern>
    </encoder>

    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <!-- rollover daily -->
        <fileNamePattern>${HOME}/archived/INFO.%d{yyyy-MM-dd}.%i.log.zip
        </fileNamePattern>
        <timeBasedFileNamingAndTriggeringPolicy
                class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
            <maxFileSize>10MB</maxFileSize>
        </timeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>

</appender>

<appender name="FILE-INSERT-WARN"
          class="ch.qos.logback.core.rolling.RollingFileAppender">
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
        <level>WARN</level>
        <onMatch>ACCEPT</onMatch>
        <onMismatch>DENY</onMismatch>
    </filter>
    <file>${HOME}/WARN.log</file>
    <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
        <Pattern>
            %d{yyyy-MM-dd HH:mm:ss} - %msg%n
        </Pattern>
    </encoder>

    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <!-- rollover daily -->
        <fileNamePattern>${HOME}/archived/WARN.%d{yyyy-MM-dd}.%i.log.zip
        </fileNamePattern>
        <timeBasedFileNamingAndTriggeringPolicy
                class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
            <maxFileSize>10MB</maxFileSize>
        </timeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>

</appender>

<appender name="FILE-INSERT-ERROR"
          class="ch.qos.logback.core.rolling.RollingFileAppender">
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
        <level>ERROR</level>
        <onMatch>ACCEPT</onMatch>
        <onMismatch>DENY</onMismatch>
    </filter>
    <file>${HOME}/ERROR.log</file>
    <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
        <Pattern>
            %d{yyyy-MM-dd HH:mm:ss} - %msg%n
        </Pattern>
    </encoder>

    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <!-- rollover daily -->
        <fileNamePattern>${HOME}/archived/ERROR.%d{yyyy-MM-dd}.%i.log.zip
        </fileNamePattern>
        <timeBasedFileNamingAndTriggeringPolicy
                class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
            <maxFileSize>10MB</maxFileSize>
        </timeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>

</appender>
<root level="DEBUG">
    <!--<appender-ref ref="FILE-INSERT-DEBUG" />-->
    <appender-ref ref="FILE-INSERT-INFO"/>
    <appender-ref ref="FILE-INSERT-WARN"/>
    <appender-ref ref="FILE-INSERT-ERROR"/>
</root>
</configuration>

Ответы [ 2 ]

0 голосов
/ 29 августа 2018

Проблема была в закомментированной строке в resources / logback.xml

<!--<appender-ref ref="FILE-INSERT-DEBUG" />-->

После закомментирования это работает:

</appender>
<root level="DEBUG">
    <appender-ref ref="FILE-INSERT-DEBUG"/>
    <appender-ref ref="FILE-INSERT-INFO"/>
    <appender-ref ref="FILE-INSERT-WARN"/>
    <appender-ref ref="FILE-INSERT-ERROR"/>
</root>
</configuration>
0 голосов
/ 29 августа 2018

Вы настраиваете уровень журнала в файле конфигурации, как это ресурсы / slf4j.xml

<configuration>
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <layout class="ch.qos.logback.classic.PatternLayout">
            <Pattern>
                %d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
            </Pattern>
        </layout>
    </appender>
    <logger name="com.base22" level="TRACE"/>
    <root level="debug">
        <appender-ref ref="STDOUT"/>
    </root>
</configuration>

P.S. Дополнительная информация Документация Logback"Автоматическая настройка с logback-test.xml или logback.xml"

...