logback配置详解

简介: 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"?>

<!-- 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"/>

目录
相关文章
|
8月前
|
Java API Apache
springboot 日志配置(logback)(一)
springboot 日志配置(logback)
239 0
|
缓存 Java API
logback配置
一、logback介绍 logback分成三个模块:logback-core,logback- classic,logback-access。 logback-core:提供了logBack的核心功能,是另外两个组件的基础; logback-classic:实现了SLF4J API; logback
662 0
|
7天前
|
Java 文件存储 Spring
【springboot】logback配置
【springboot】logback配置
18 1
QGS
|
4月前
|
Java 数据库连接 Apache
Springboot日志框架logback与log4j2
Springboot日志框架logback与log4j2
QGS
45 0
|
5月前
|
Java API 开发者
Logback简介与配置详解
在开发和维护Spring Boot应用程序时,一个强大而灵活的日志框架是至关重要的。Spring Boot默认集成了Logback,一个高性能的Java日志框架。本文将介绍如何配置Logback以满足你的日志记录需求。
107 1
 Logback简介与配置详解
|
8月前
|
XML SQL Java
springboot 日志配置(logback)(二)
springboot 日志配置(logback)(二)
104 0
|
11月前
|
Java API 计算机视觉
springboot启动报错LoggerFactory is not a Logback LoggerContext but Logback...
今天做人脸识别的Demo,引入的百度的API,里面用了slf4j,然后就导致日志冲突了。
|
12月前
|
Java Maven 开发者
SpringBoot整合logback日志
SpringBoot整合logback日志
217 0
|
监控 Java Shell
(二)Logback配置
Logback通过加载配置文件的方式来初始化配置,配置文件的加载顺序如下: 1)Logback首先会去类路径下找名为logback-test.xml的文件。 2)如果没有找到如上文件,会去类路径下找名为logback.groovy的文件。 3)如果没有找到如上文件,会去类路径下找名logback.xml的文件。
(二)Logback配置
|
Oracle Java 关系型数据库
SpringBoot应用自定义logback日志
SpringBoot应用自定义logback日志
363 0
SpringBoot应用自定义logback日志