欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

logback和slf4j简介

程序员文章站 2022-07-03 16:23:18
...

logback是java的日志开源组件,其性能要优于log4j,logback主要模块有三个

logback-core:核心代码模块。

logback-classic:log4j的一个改良版本,同时实现了slf4j的接口,这使得切换其他日志组件变得很容易。

logback-access:访问模块与Servlet容器集成提供通过Http来访问日志的功能。

使用logback

首先在maven项目中引入依赖

<!--这个依赖包含了 logback-core 和 slf4j-api的依赖-->

<dependency>

    <groupId>ch.qos.logback</groupId>

    <artifactId>logback-classic</artifactId>

    <version>1.2.3</version>

</dependency>

接下来就可以直接在代码中使用slf4j的接口获取Logger输出日志

//这是slf4j的接口,由于我们引入了logback-classic依赖,所以底层实现是logback

private static final Logger LOGGER = LoggerFactory.getLogger(Test.class);

public static void main(String[] args) throws InterruptedException{

     LOGGER.info("hello world");

}

配置logback

配置文件加载顺序
logback在启动的时候,会按照如下顺序加载配置文件,上面的顺序表示优先级,使用java -D配置的优先级最高,只要获取到配置后就不会再执行下面的流程

1.如果java程序启动时指定了logback.configurationFile属性,就用该属性指定的配置文件。如java -Dlogback.configurationFile=/path/to/mylogback.xml Test,这样执行Test类的时候就会加载/path/to/mylogback.xml配置。

2.在classpath中查找logback.groovy文件。

3.在classpath中查找logback-test.xml文件。

4.在classpath中查找logback.xml文件。

5.如果是 jdk6+,那么会调用ServiceLoader 查找 com.qos.logback.classic.spi.Configurator接口的第一个实现类。

6.自动使用ch.qos.logback.classic.BasicConfigurator,在控制台输出日志。

slf4j日志输出级别

slf4j日志输出级别从小到大依序是tracedebuginfowarnerror

logback.xml文件配置示例

<?xml version="1.0" encoding="UTF-8"?>

    <configuration debug="false">

    <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径-->

        <property name="LOG_HOME" value="/home"/><!-- 控制台输出 -->

        <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">

            <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">

            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->

            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>

            </encoder>

        </appender>

        <!-- 按照每天生成日志文件 -->

        <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">    

            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

                <!--日志文件输出的文件名-->                               <FileNamePattern>${LOG_HOME}/TestWeb.log.%d{yyyy-MM-dd}.log</FileNamePattern>

                 <!--日志文件保留天数-->

                 <MaxHistory>30</MaxHistory>

            </rollingPolicy>

            <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">

                <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->

                <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>

            </encoder>

            <!--日志文件最大的大小-->

            <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">    

                <MaxFileSize>10MB</MaxFileSize>

             </triggeringPolicy>

        </appender>

        <!-- 日志输出级别 -->

        <root level="INFO">

            <appender-ref ref="STDOUT"/>

        </root>

</configuration>

configuration子节点介绍
1.contextName节点

设置日志上下文名称,后面输出格式中可以通过定义 %contextName 来打印日志上下文名称。

2.property节点

用来设置相关变量,通过key-value的方式配置,然后在后面的配置文件中通过 ${key}来访问。

3.appender 节点

日志输出组件,主要负责日志的输出以及格式化日志。

ConsoleAppender:向控制台输出日志内容的组件,只要定义好encoder节点就可以使用。

FileAppender:向文件输出日志内容的组件,用法也很简单,不过由于没有日志滚动策略,一般很少使用

RollingFileAppender:向文件输出日志内容的组件,同时可以配置日志文件滚动策略,在日志达到一定条件后生成一个新的日志文件。

appender节点中有一个子节点filter,配置具体的过滤器,这样用这个appender输出日志的时候都会经过这个过滤器,日志级别低于过滤器中配置级别的都不会输出来。

slf4j

slf4j只是一套标准,简单来说就是定义了一系列接口,它并不提供任何的具体实现。所以,我们使用这套接口进行开发,可以任意的切换底层的实现框架。

例如想要将项目中的log4j换成logback,由于项目代码是面向slf4j接口的,因此只要将log4j的依赖换成logback就可以了。