引用
logback 配置详解(一)
logback 配置详解(二)
logback 配置详解(三)
logback高级特性使用(一)
logback高级特性使用(二)
logback高级特性使用(三)
应用日志配置
console日志
:本地调试时用。
file日志
:记录应用操作信息及错误信息。通常小项目一个appliation.log就够了,用来记录错误日志;大点的项目可能会记录一些用户操作日志、操作流程日志等用于后期分析,一个或多个日志文件。日志回滚策略见配置。
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<include resource="org/springframework/boot/logging/logback/defaults.xml" />
<property name="APP_NAME" value="sample-liyuan932-com" />
<property name="LOG_PATH" value="${user.home}/${APP_NAME}/logs" />
<property name="CONSOLE_LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss} %-5level %logger - %msg%n" />
<property name="FILE_LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss} %-5level %logger - %msg%n" />
<!-- console appender -->
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>${CONSOLE_LOG_PATTERN}</pattern>
<charset>utf8</charset>
</encoder>
</appender>
<!-- application appender ,应用日志 -->
<appender name="APPLICATION" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${LOG_PATH}/application.log</file>
<encoder>
<pattern>${FILE_LOG_PATTERN}</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<!--按天归档,单日志文件最多100MB,30天的日志周期,最大不能超过20GB-->
<fileNamePattern>${LOG_PATH}/application.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<maxHistory>30</maxHistory>
<maxFileSize>100MB</maxFileSize>
<totalSizeCap>20GB</totalSizeCap>
</rollingPolicy>
</appender>
<!-- operator appender ,操作日志 -->
<appender name="OPERATION" class="ch.qos.logback.core.rolling.RollingFileAppender"
>
<file>${LOG_PATH}/operation.log</file>
<encoder>
<pattern>${FILE_LOG_PATTERN}</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<fileNamePattern>${LOG_PATH}/operation.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<maxHistory>30</maxHistory>
<maxFileSize>100B</maxFileSize>
<totalSizeCap>20GB</totalSizeCap>
</rollingPolicy>
</appender>
<!-- operator Logger -->
<logger name="OPERATION" level="INFO" additivity="false">
<appender-ref ref="OPERATION" />
</logger>
<!-- roo Logger -->
<root level="WARN">
<appender-ref ref="CONSOLE" />
<appender-ref ref="APPLICATION" />
</root>
</configuration>
测试日志配置
测试日志通常只记录到控制台,这里我专门用来记录mybatis的sql执行日志,并以错误信息高亮显示。
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<include resource="org/springframework/boot/logging/logback/defaults.xml" />
<property name="CONSOLE_LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss} %-5level %logger - %msg%n" />
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<target>System.out</target>
<encoder>
<pattern>${CONSOLE_LOG_PATTERN}</pattern>
<charset>UTF-8</charset>
</encoder>
</appender>
<appender name="STDERR" class="ch.qos.logback.core.ConsoleAppender">
<target>System.err</target>
<encoder>
<pattern>${CONSOLE_LOG_PATTERN}</pattern>
<charset>UTF-8</charset>
</encoder>
</appender>
<logger name="org.apache" level="WARN"/>
<logger name="org.springframework" level="WARN"/>
<logger name="org.mybatis.spring" level="WARN"/>
<logger name="com.github.miemiedev.mybatis.paginator.support" level="WARN"/>
<logger name="org.springframework.jdbc.datasource" level="WARN"/>
<logger name="com.liyuan932.sample.dal.mapper" level="DEBUG" additivity="false">
<appender-ref ref="STDERR"/>
</logger>
<root level="DEBUG">
<appender-ref ref="STDOUT"/>
</root>
</configuration>
Spring Boot
Spring Boot实战之配置使用Logback进行日志记录
Spring Boot默认使用logback,且有默认配置base.xml,还可以在application.properties中自定义配置,然而并没有什么鸟用,复杂一点的还是得用配置文件。
配置文件以logback.xml或logback-spring.xml命名扔到src/main/ressources下面,对于src/test/java下写的测试代码亦会生效,不过还是建议在src/test/resources下再写一个,毕竟场景不同,配置也会不一样,参见上面的配置。