Backend/Spring

Spring Boot Base logback

Seyun(Marco) 2020. 9. 16. 12:51
728x90

Spring Boot Base logback

LogBack이란?

  • Log를 효율적으로 관리하기 위해서 사용하는 것입니다.
  • 현재 core, classic, access의 세가지 모듈로 나눠져 있다.
  • 코어 모듈은 다른 두 개의 모듈을 위한 기반이며, classic 모듈은 코어를 확장하는데 사용하며 access는 서블릿 컨테이너와 통합되어 HTTP-access 로그 기능을 제공한다.
  • 스프링에서는 기본적으로 logback을 사용한다.

base.xml

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

<!--
Base logback configuration provided for compatibility with Spring Boot 1.1
-->

<included>
    <include resource="org/springframework/boot/logging/logback/defaults.xml" />
    <property name="LOG_FILE" value="${LOG_FILE:-${LOG_PATH:-${LOG_TEMP:-${java.io.tmpdir:-/tmp}}}/spring.log}"/>
    <include resource="org/springframework/boot/logging/logback/console-appender.xml" />
    <include resource="org/springframework/boot/logging/logback/file-appender.xml" />
    <root level="INFO">
        <appender-ref ref="CONSOLE" />
        <appender-ref ref="FILE" />
    </root>
</included>
  • include는 다른 로그 관련 설정 파일을 불러오기 위해 사용한다.
  • property는 값을 변수처럼 사용하기 위해 사용한다.
  • 현재 이 파일을 보면 defaults.xml과 console.appender.xml, file-appender.xm의 파일을 불러오고 있으며, 로그레벨 INFO로 설정하여 콘솔과 파일 둘다 사용하게 된다.
  • 아울러 파일로 로그를 관리할때 어느 위치에 저장하는지와 spirng.log라는 이름으로 저장되는걸 확인할 수 있다.

defaults.xml

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

<!--
Default logback configuration provided for import
-->

<included>
    <conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter" />
    <conversionRule conversionWord="wex" converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter" />
    <conversionRule conversionWord="wEx" converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter" />
    <property name="CONSOLE_LOG_PATTERN" value="${CONSOLE_LOG_PATTERN:-%clr(%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss.SSS}}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"/>
    <property name="FILE_LOG_PATTERN" value="${FILE_LOG_PATTERN:-%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss.SSS}} ${LOG_LEVEL_PATTERN:-%5p} ${PID:- } --- [%t] %-40.40logger{39} : %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"/>

    <logger name="org.apache.catalina.startup.DigesterFactory" level="ERROR"/>
    <logger name="org.apache.catalina.util.LifecycleBase" level="ERROR"/>
    <logger name="org.apache.coyote.http11.Http11NioProtocol" level="WARN"/>
    <logger name="org.apache.sshd.common.util.SecurityUtils" level="WARN"/>
    <logger name="org.apache.tomcat.util.net.NioSelectorPool" level="WARN"/>
    <logger name="org.eclipse.jetty.util.component.AbstractLifeCycle" level="ERROR"/>
    <logger name="org.hibernate.validator.internal.util.Version" level="WARN"/>
    <logger name="org.springframework.boot.actuate.endpoint.jmx" level="WARN"/>
</included>
  • 여기서는 콘솔 로그 패턴과 파일 로그 패턴을 정의하고 있으며, 몇몇의 로그들에 대해서 어느 레벨까지 출력을 할 것인지 정하고 있다.
  • 위와 같이 정의를 한다면 org.apache.catalina.startup.DigesterFactory의 대한 로그는 에러만 나오게 될것 이다.

console-appender.xml

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

<!--
Console appender logback configuration provided for import, equivalent to the programmatic
initialization performed by Boot
-->

<included>
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>${CONSOLE_LOG_PATTERN}</pattern>
        </encoder>
    </appender>
</included>
  • 아주 간단하게 패턴만 입력하여 사용한다.
  • 이미 defaults.xml에서 패턴을 정의했기 때문에 우리가 기본적으로 스프링부트를 실행했을 때 보는 로그들은 이걸로 인해 출력되게 된다.

file-appender.xml

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

<!--
File appender logback configuration provided for import, equivalent to the programmatic
initialization performed by Boot
-->

<included>
    <appender name="FILE"
        class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder>
            <pattern>${FILE_LOG_PATTERN}</pattern>
        </encoder>
        <file>${LOG_FILE}</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <cleanHistoryOnStart>${LOG_FILE_CLEAN_HISTORY_ON_START:-false}</cleanHistoryOnStart>
            <fileNamePattern>${ROLLING_FILE_NAME_PATTERN:-${LOG_FILE}.%d{yyyy-MM-dd}.%i.gz}</fileNamePattern>
            <maxFileSize>${LOG_FILE_MAX_SIZE:-10MB}</maxFileSize>
            <maxHistory>${LOG_FILE_MAX_HISTORY:-7}</maxHistory>
            <totalSizeCap>${LOG_FILE_TOTAL_SIZE_CAP:-0}</totalSizeCap>
        </rollingPolicy>
    </appender>
</included>
  • 로그 파일에 대한 기본적인 설정들이 들어가 있다.
  • application.yml 또는 properties에서 정의하지 않으면 옆에 있는 기본값이 들어가게 된다.
logging.file.name:
logging.file.max-history:
...
  • 위와 같은 key로 설정하면 본인이 설정한 값으로 설정이 가능하다.

커스텀 logback에서 사용하는 방법

  • 파일과 콘솔 둘다 사용하고 싶다면 아래와 같이 include 해주면 된다.
<include resource="org/springframework/boot/logging/logback/base.xml" />
  • 콘솔만 사용하고 싶다면 아래와 같이 include 해주면된다.
  • 이때 주의할 점은 아래와 같이 defaults.xml을 먼저 선언해준 다음에 console-appender.xml을 선언해줘야 한다는 것이다.
  • defaults.xml에 CONSOLE_LOG_PATTERN 이 값이 있다 보니 꼭 필요하다.
<include resource="org/springframework/boot/logging/logback/defaults.xml" />
<include resource="org/springframework/boot/logging/logback/console-appender.xml" />
728x90
728x90