logback

5 篇文章 0 订阅

引用

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下再写一个,毕竟场景不同,配置也会不一样,参见上面的配置。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值