java日志框架--logback(logback入门案例logback配置(fileappender异步日志拆分appender过滤器)logback-access)(代码片段)

CodeJiao CodeJiao     2022-12-07     441

关键词:

1. Logback

Logback是由log4j创始人设计的另一个开源日志组件,性能比log4j要好。
官方网站:https://logback.qos.ch/index.html

Logback主要分为三个模块:

  • logback-core:其它两个模块的基础模块
  • logback-classic:它是log4j的一个改良版本,同时它完整实现了slf4j API
  • logback-access:访问模块与Servlet容器集成提供通过Http来访问日志的功能

1.1 Logback入门案例

首先创建一个Maven工程:

然后添加Logback相关的依赖,这里选择slf4j日志门面技术加上logback日志实现框架:

    <dependencies>
        <!--        单元测试依赖-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>
        <!--        slf4j日志门面-->
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>1.7.25</version>
        </dependency>
        <!--        logback相关的依赖-->
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-classic</artifactId>
            <version>1.2.3</version>
        </dependency>
    </dependencies>

编写测试代码:

LogbackTest.java

package com.tian.logs;

import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class LogbackTest 

    public static final Logger LOGGER = LoggerFactory.getLogger(LogbackTest.class);


    // 快速入门
    @Test
    public void testQuick() throws Exception 
        // 日志输出
        LOGGER.error("error");
        LOGGER.warn("wring");
        LOGGER.info("info");
        LOGGER.debug("debug");// 默认级别
        LOGGER.trace("trace");
    

运行结果:


1.2 logback配置

logback会依次读取以下类型配置文件:

  • logback.groovy
  • logback-test.xml
  • logback.xml 如果均不存在会采用默认配置

logback组件之间的关系:

  1. Logger:日志的记录器,把它关联到应用的对应的context上后,主要用于存放日志对象,也
    可以定义日志类型、级别。
  2. Appender:用于指定日志输出的目的地,目的地可以是控制台、文件、数据库等等。
  3. Layout:负责把事件转换成字符串,格式化的日志信息的输出。在logback中Layout对象被封
    装在encoder中。

1.2.1 logback基本配置


logback.xml

配置的这些属性都是通过set方法注入的。

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

    <!--
        配置集中管理属性
        我们可以直接改属性的 value 值
        格式:$name
    -->
    <property name="pattern" value="[%-5level] %dyyyy-MM-dd HH:mm:ss.SSS %c %M %L [%thread] %m%n"/>
    <!--
    日志输出格式:
        %-5level 从左显示5个字符宽度
        %dyyyy-MM-dd HH:mm:ss.SSS日期
        %c类的完整名称
        %M为method
        %L为行号
        %thread线程名称
        %m或者%msg为信息
        %n换行
      -->
    <!--控制台日志输出的 appender-->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <!--控制输出流对象 默认 System.out 改为 System.err-->
        <target>System.err</target>
        <!--日志消息格式配置-->
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>$pattern</pattern>
        </encoder>
    </appender>

    <!--root logger 配置 , ALL表示开启所有日志级别 OFF表示关闭日志
    还有5个日志级别为TRACE, DEBUG, INFO, WARN, ERROR。不区分大小写-->
    <root level="ALL">
        <appender-ref ref="console"/>
    </root>
</configuration>

运行结果:


1.2.2 FileAppender配置


logback.xml

配置的这些属性都是通过set方法注入的。

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

    <!--
        配置集中管理属性
        我们可以直接改属性的 value 值
        格式:$name
    -->
    <property name="pattern" value="[%-5level] %dyyyy-MM-dd HH:mm:ss.SSS %c %M %L [%thread] %m%n"/>
    <!--
    日志输出格式:
        %-5level 从左显示5个字符宽度
        %dyyyy-MM-dd HH:mm:ss.SSS日期
        %c类的完整名称
        %M为method
        %L为行号
        %thread线程名称
        %m或者%msg为信息
        %n换行
      -->
    <!--控制台日志输出的 appender-->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <!--控制输出流对象 默认 System.out 改为 System.err-->
        <target>System.err</target>
        <!--日志消息格式配置-->
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>$pattern</pattern>
        </encoder>
    </appender>

    <!--定义日志文件保存路径属性-->
    <property name="log_dir" value="c:/logs"/>

    <!--日志文件输出的 appender-->
    <appender name="file" class="ch.qos.logback.core.FileAppender">
        <!--日志文件保存路径-->
        <file>$log_dir/logback.log</file>
        <!--日志消息格式配置-->
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>$pattern</pattern>
        </encoder>
    </appender>

    <!--html 格式日志文件输出 appender-->
    <appender name="htmlFile" class="ch.qos.logback.core.FileAppender">
        <!--日志文件保存路径-->
        <file>$log_dir/logback.html</file>
        <!--html 消息格式配置-->
        <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
            <layout class="ch.qos.logback.classic.html.HTMLLayout">
                <pattern>%-5level%dyyyy-MM-dd HH:mm:ss.SSS%c%M%L%thread%m</pattern>
            </layout>
        </encoder>
    </appender>


    <!--root logger 配置 , ALL表示开启所有日志级别 OFF表示关闭日志
    还有5个日志级别为TRACE, DEBUG, INFO, WARN, ERROR。不区分大小写-->
    <root level="ALL">
        <appender-ref ref="console"/>
        <appender-ref ref="file"/>
        <appender-ref ref="htmlFile"/>
    </root>
</configuration>

运行结果:



1.2.3 logback 的拆分Appender(按照时间和空间拆分日志文件,包括压缩日志文件)


logback.xml

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

    <!--
        配置集中管理属性
        我们可以直接改属性的 value 值
        格式:$name
    -->
    <property name="pattern" value="[%-5level] %dyyyy-MM-dd HH:mm:ss.SSS %c %M %L [%thread] %m%n"/>
    <!--
    日志输出格式:
        %-5level 从左显示5个字符宽度
        %dyyyy-MM-dd HH:mm:ss.SSS日期
        %c类的完整名称
        %M为method
        %L为行号
        %thread线程名称
        %m或者%msg为信息
        %n换行
      -->
    <!--控制台日志输出的 appender-->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <!--控制输出流对象 默认 System.out 改为 System.err-->
        <target>System.err</target>
        <!--日志消息格式配置-->
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>$pattern</pattern>
        </encoder>
    </appender>

    <!--定义日志文件保存路径属性-->
    <property name="log_dir" value="c:/logs"/>

    <!--日志拆分和归档压缩的 appender 对象-->
    <appender name="rollFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!--日志文件保存路径-->
        <file>$log_dir/roll_logback.log</file>
        <!--日志消息格式配置-->
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>$pattern</pattern>
        </encoder>
        <!--指定拆分规则-->
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!--按照时间和压缩格式声明拆分的文件名 如果你不想压缩, 则不加.gz-->
            <!--%i可以指定按照文件大小拆分的序号-->
            <!--yyyy-MM-dd-HH-mm-ss 可以指定按照秒拆分日志,当前是按照天拆分-->
            <fileNamePattern>$log_dir/rolling%i.%dyyyy-MM-dd.log.gz</fileNamePattern>
            <!--按照文件大小拆分-->
            <maxFileSize>1MB</maxFileSize>
        </rollingPolicy>
    </appender>

    <!--root logger 配置 , ALL表示开启所有日志级别 OFF表示关闭日志
    还有5个日志级别为TRACE, DEBUG, INFO, WARN, ERROR。不区分大小写-->
    <root level="ALL">
        <appender-ref ref="console"/>
        <appender-ref ref="rollFile"/>
    </root>
</configuration>

更改测试的代码,使打印日志重复10000次,以此来增大日志文件的大小

运行结果:


1.2.4 logback的过滤器


logback.xml

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

    <!--
        配置集中管理属性
        我们可以直接改属性的 value 值
        格式:$name
    -->
    <property name="pattern" value="[%-5level] %dyyyy-MM-dd HH:mm:ss.SSS %c %M %L [%thread] %m%n"/>
    <!--
    日志输出格式:
        %-5level 从左显示5个字符宽度
        %dyyyy-MM-dd HH:mm:ss.SSS日期
        %c类的完整名称
        %M为method
        %L为行号
        %thread线程名称
        %m或者%msg为信息
        %n换行
      -->
    <!--控制台日志输出的 appender-->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <!--控制输出流对象 默认 System.out 改为 System.err-->
        <target>System.err</target>
        <!--日志消息格式配置-->
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>$pattern</pattern>
        </encoder>
        <!--filter配置-->
        <filter class="ch.qos.logback.classic.filter.LevelFilter"> <!--设置拦截日志级别-->
            <level>WARN</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>

    <!--root logger 配置 , ALL表示开启所有日志级别 OFF表示关闭日志
    还有5个日志级别为TRACE, DEBUG, INFO, WARN, ERROR。不区分大小写-->
    <root level="ALL">
        <appender-ref ref="console"/>
    </root>
</configuration>

测试代码:

LogbackTest.java

package com.tian.logs;

import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class LogbackTest 

    public static final Logger LOGGER = LoggerFactory.getLogger(LogbackTest.class);


    // 快速入门
    @Test
    public void testQuick() throws Exception 
        // 日志输出
        LOGGER.error("error");
        LOGGER.warn("wring");
        LOGGER.info("info");
        LOGGER.debug("debug");// 默认级别
        LOGGER.trace("trace");
    

运行结果:


1.2.5 异步日志

同步(默认)的情况下,需要等待记录完日志文件后才可以继续执行下一步,在生产环境下,这是十分影响效率的。异步日志就可以很好的解决这个问题,它可以使得程序不需要等待日志记录完成就可以执行下一步操作。

开启异步日志:

logback.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <property name="pattern" value="[%-5level] %dyyyy-MM-dd HH:mm:ss.SSS %c %M %L [%thread] %m%n"/>
    <!--定义日志文件保存路径属性-->
    <property name="log_dir" value="c:/logs"/>

    <!--日志拆分和归档压缩的 appender 对象-->
    <appender name="rollFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!--日志文件保存路径-->
        <file>$log_dir/roll_logback.log</file>
        <!--日志消息格式配置-->
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>$pattern</pattern>
        </encoder>
        <!--指定拆分规则-->
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!--按照时间和压缩格式声明拆分的文件名 如果你不想压缩, 则不加.gz-->
            <!--%i可以指定按照文件大小拆分的序号-->
            <!--yyyy-MM-dd-HH-mm-ss 可以指定按照秒拆分日志,当前是按照天拆分-->
            <fileNamePattern>$log_dir/rolling%i.%dyyyy-MM-dd.log.gz</fileNamePattern>
            <!--按照文件大小拆分-->
            <maxFileSize>1MB</maxFileSize>
        </rollingPolicy>
    </appender>

    <!--异步日志-->
    <appender name="async" class="ch.qos.logback.classic.AsyncAppender">
        <appender-ref ref="rollFile"/>
    </appender>

    <!--root logger 配置 , ALL表示开启所有日志级别 OFF表示关闭日志
    还有5个日志级别为TRACE, DEBUG, INFO, WARN, ERROR。不区分大小写-->
    <root level="ALL">
        <appender-ref ref="async"/>
    </root>

</configuration>

测试代码:

LogbackTest.java

package com.tian.logs;

import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class LogbackTest 

    public static final Logger LOGGER = LoggerFactory.getLogger(LogbackTest.class);


    // 快速入门
    @Test
    public void testQuick() throws Exception 
        for (int i = 0; i < 100000; i++) 
            // 日志输出
            LOGGER.error("error");
            LOGGER.warn("wring");
            LOGGER.info("info");
            LOGGER.debug("debug");// 默认级别
            LOGGER.trace("trace");
        
    

运行结果:
查看详情

日志-logback

参考:http://www.importnew.com/22290.html一概述  1.1 LogBack、Slf4j和Log4j之间的关系    1)Slf4j(TheSimpleLoggingFacadefor Java)是一个简单日志门面抽象框架本身只提供了日志FacadeAPI和一个简单的日志类实现,一般常配合Log4j,L... 查看详情

java日志框架学习--logback和log4j2--下

Java日志框架学习--LogBack和Log4j2--下LogbackLogback中的组件Logback配置文件日志输出格式使用演示配置文件输出到控制台输出到控制台和文件输出到控制台,文件和html日志拆分过滤器异步日志自定义LoggerLog4jLog4j2简介Log4j2特征应用演示... 查看详情

slf4j与logback日志配置详解

背景javaweb下有好几种日志框架,比如:logback,log4j,log4j2(slj4f并不是一种日志框架,它相当于定义了规范,实现了这个规范的日志框架就能够用slj4f调用)。其中性能最高的应该使logback了,而且springboot默认使用的也是logback日... 查看详情

logback日志框架的简单使用(代码片段)

最近在自己搭建项目的时候,遇到logback选的问题,现在记录如下在框架中使用logback日志框架,关于logback和log4j日志框架的选择,这里就不多说了网上百度一大堆,总之一句话logback要比log4j效率高,性能好,配置灵活。1.首先在ma... 查看详情

springboot日志logback

...很多优秀的日志工具比如log4j, springboot中默认集成了logback ,关于logback大家可以了解一下 https://logback.qos.ch/当然,springboot中我们也可以使用其他日志框架:Bydefault,ifyouusethe“Starters”,Logbackisusedforlog 查看详情

日志框架之logback

 1日志框架选择  日志门面:SLF4J  日志实现:Logback 2实现控制台的日志打印输出01  2.1在需要实现日志信息打印的类中实例化Logger对象    privatefinalLoggerlogger=LoggerFactory.getLogger(getClass());      注意01:ge... 查看详情

springboot使用之三:springboot使用logback日志

springboot默认使用的日志就是logback,所以使用logback不需要添加日志相关依赖了,执行添加logback.xml配置文件,springboot这个聪明的框架便能识处理你的配置。做法:将logback.xml放在resources下(classpath)下即可。配置参考如下:<?xm... 查看详情

日志框架--logback(代码片段)

logback背景介绍:SLF4J(SimpleLoggingFacadeforJava)是一个日志API接口,SLF4J提供TRACE,DEBUG,INFO,WARN,ERROR五种级别,而log4j和logback就是对SLF4J的具体实现。logback的性能优于log4j。logback-core:其它两个模块的基础模块logback-classic:它是log4j的一... 查看详情

logback使用

logback简介   Slf4j是TheSimpleLoggingFacadeforJava的简称,是一个简单日志门面抽象框架,它本身只提供了日志FacadeAPI和一个简单的日志类实现,一般常配合Log4j,LogBack,java.util.logging使用。Slf4j作为应用层的Log接入时,程序可... 查看详情

logback简介

转载:http://aub.iteye.com/blog/1101222logback简介 CekiGülcü在Java日志领域世界知名。他创造了Log4J,这个最早的Java日志框架即便在JRE内置日志功能的竞争下仍然非常流行。随后他又着手实现SLF4J这个“简单的日志前端接口(Fa?ade)”... 查看详情

logback日志框架第三方jar包下载教程

logback-core下载(点击下方链接即可跳转):https://logback.qos.ch/download.html点击选择对应的模块:选择对应的版本:(本篇以1.2.3版本为例子)选择对应的jar包并保存到本地即可:由于logback-classic的下载过程与logback- 查看详情

日志框架之logback的使用与详细配置(代码片段)

(日志框架之Logback的使用与详细配置)Logback概述Logback特点:高性能:采用异步日志机制,可以将日志操作和业务逻辑分离,从而大幅度提升系统的性能。灵活的配置:支持多种不同的配置方式,包括基于XML、Groovy、JSON等格式的配... 查看详情

日志框架logback相对于log4j的优势

日志框架logback相对于log4j的优势。更快的实现 Logback的内核重写了,在一些关键执行路径上性能提升10倍以上。而且logback不仅性能提升了,初始化内存加载也更小了。 非常充分的测试 Logback经过了几年,数不清小时的... 查看详情

java日志信息存库(logback篇)

一、Logback简介  Logback是由log4j创始人设计的又一个开源日志组件。logback当前分成三个模块:logback-core,logback-classic和logback-access。logback-core是其它两个模块的基础模块。logback-classic是log4j的一个改良版本。此外logback-classic完整... 查看详情

springboot实践:logback日志配置

1、logback是什么?工作中一直用的是log4j日志框架,接触了SpringBoot后,因为logback是默认框架,才开始进行了解。来看下官网的相关介绍。 可以看到,logback是log4j的进化版,是为了替代log4j的。logback分三个模块:logback-core:核... 查看详情

akka中使用logback日志框架

...可以整合SLF4J这样的日志系统,下面介绍如何在Akka中使用Logback记录日志。 1.创建Maven工程引入相关依赖。<projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSche 查看详情

springboot日志框架

Java有很多日志系统,例如,JavaUtilLogging,Log4J,Log4J2,Logback等。SpringBoot也提供了不同的选项,比如日志框架可以用logback或log4j等。 默认的日志框架logback例如,maven依赖中添加了spring-boot-starter-logging。<dependency><groupId>org.... 查看详情