1. 설정
로거를 통해 기록이 이뤄지면서 원하는 바는 환경 별로 분리된 파일을 유지하는 것이다. local에서는 콘솔로 남기고 싶고, dev 및 prod에서는 서로 다른 파일로 남기고 싶었다. 또한 test 환경에서는 통합 테스트를 진행할 시 테스트 케이스가 틀리지 않는 한 별도로 출력을 원하지 않았다.
스프링 부트에서는 로깅 구현체로 logback을 이용하는데, 이를 위한 설정으론 main 경로의 resources에 logback-spring.xml을 두고, 설정 값을 작성해야 한다. application.yml에 작성하는 방법도 있는 것 같지만, 왠지 잘 되지 않았다.
우선 콘솔에 남길지 말지의 여부는 appender를 이용하여 설정하고, 각 로거가 appender를 참조하도록 작성하면 된다. 그리고 이와 같이 작성한 설정들을 springProfile로 분리해내면 된다. 특히 로깅 형식을 위해 appender의 encoder를 작성했다. 또한 dev 및 prod에서는 날짜 별 및 로그 파일 크기 별로 Rolloing이 가능해야 하므로, rollingPolicy도 작성했다.
위 상황에 부합하는 xml은 아래와 같다.
<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="30 seconds">
<springProfile name="local">
<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>[%d{HH:mm:ss.SSS}][%-5level][%logger{36}.%method:line%line] - %msg%n</pattern>
</encoder>
</appender>
<logger name="org.springframework" level="info" additivity="false">
<appender-ref ref="console"/>
</logger>
<root level="info">
<appender-ref ref="console"/>
</root>
</springProfile>
<springProfile name="dev">
<appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<fileNamePattern>logs/dev/access_%d{yyyy-MM-dd}_%i.log</fileNamePattern>
<maxHistory>7</maxHistory>
<maxFileSize>300MB</maxFileSize>
</rollingPolicy>
<encoder>
<pattern>[%d{HH:mm:ss.SSS}][%-5level][%logger.%method:line%line] - %msg%n</pattern>
</encoder>
</appender>
<logger name="org.springframework" level="info" additivity="false">
<appender-ref ref="file"/>
</logger>
<root level="info">
<appender-ref ref="file"/>
</root>
</springProfile>
<springProfile name="prod">
<appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<fileNamePattern>logs/prod/access_%d{yyyy-MM-dd}_%i.log</fileNamePattern>
<maxHistory>7</maxHistory>
<maxFileSize>300MB</maxFileSize>
</rollingPolicy>
<encoder>
<pattern>[%d{HH:mm:ss.SSS}][%-5level][%logger.%method:line%line] - %msg%n</pattern>
</encoder>
</appender>
<logger name="org.springframework" level="info" additivity="false">
<appender-ref ref="file"/>
</logger>
<root level="info">
<appender-ref ref="file"/>
</root>
</springProfile>
</configuration>
XML
복사
위 설정에서 로거에 달려 있는 additivity의 false는 중복 로그를 없애기 위한 옵션이다.