logback配置详解

Logback是由log4j创始人设计的又一个开源日志组件。logback当前分成三个模块:logback-core,logback- classic和logback-access。logback-core是其它两个模块的基础模块。logback-classic是log4j的一个 改良版本。此外logback-classic完整实现SLF4J API使你可以很方便地更换成其它日志系统如log4j或JDK14 Logging。logback-access访问模块与Servlet容器集成提供通过Http来访问日志的功能

Logback相比log4j的优势,

比log4j更快,重写了内核,在一些关键路径上性能提升10倍,内存占用也更少。经过大量的测试,和log4j测试不在一个量级。

logback-classic是SLF4J的实现,切换其他日志框架非常方便,文档丰富并且不断更新,支持Groovy风格的配置文件配置文件自动重新加载,如果更新了配置文件,logback-classic可以自动重新加载。

自动删除日期较老的日志文件,maxHistory属性,你可以控制已经产生日志文件的最大数量。如果设置maxHistory为12,那那些log文件超过12个月的都会被自动移除。

自动压缩归档的日志文件,压缩文件是异步进行,不影响应用。配置文件可以处理不同的环境开发,测试,生产),这样一个配置文件就可以适应多个环境。

SiftingAppender(一个非常多功能的Appender) 它可以用来分割日志文件根据任何一个给定的运行参数。如,SiftingAppender能够区别日志事件跟进用户的Session,然后每个用户会有一个日志文件。

老样子直接上示例

<?xml version="1.0"?>
<configuration>
    <!-- ch.qos.logback.core.ConsoleAppender 控制台输出 -->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>

            <!--%msg日志信息
                %logger{n}显示类信息长度
                %l %line行号
                %date %d{yyyy-MM-dd HH:mm:ss:SSS}时间
                %-3relative显示从程序创建到日志输出的时间 单位毫秒
                %thread显示线程名
                %p %level %le 显示输出日志级别
                %f %file 输出文件名效率低
                %c %class 输出类名 效率高

            -->
            <pattern>[%-5level %L row] %d{yyyy-MM-dd HH:mm:ss} [%thread]
                %logger{36} - %msg%n
            </pattern>
        </encoder>
    </appender>
    <!--日志输出文件-->
    <property name="HOME_LOGS" value="./logs"/>
    <appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!--按天生成文件-->
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>[%-5level %L row] %d{yyyy-MM-dd HH:mm:ss} [%thread] %logger{36} - %msg%n</pattern>
        </encoder>
        <rollingRolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 日志文件输出的文件名 -->
            <!-- %d表示按天拆分文件,即每天新生成一个日志文件 -->
            <FileNamePattern>${LOG_HOME}/mylog%d{yyyy-MM-dd}.log</FileNamePattern>
            <!-- 日志文件保留天数(天) -->
            <MaxHistory>60</MaxHistory>
        </rollingRolicy>
        <!-- 日志文件最大的大小 -->
        <triggeringPolicy
                class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
            <MaxFileSize>20MB</MaxFileSize>
        </triggeringPolicy>


    </appender>

    <!--    <appender name="file" class="ch.qos.logback.core.FileAppender">-->
    <!--        <file>logs/app.log</file>-->
    <!--        <append>true</append>-->
    <!--        <encoder>-->
    <!--            <pattern>[%-5level %L row] %d{yyyy-MM-dd HH:mm:ss} [%thread]-->
    <!--                %logger{36} - %msg%n-->
    <!--            </pattern>-->
    <!--        </encoder>-->
    <!--    </appender>-->
    <!-- 日志级别 off info debug -->
    <root>
        <level value="off"/>
        <appender-ref ref="STDOUT"/>
    </root>
    <!--    指定logback使用的包-->
    <logger name="cn.chenxiejia" level="debug"/>
</configuration>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值