Java:Logback日志

本文介绍了日志技术的基本概念,重点阐述了Logback日志框架的体系结构、核心配置及其实现步骤。包括如何在项目中整合slf4j-api、logback-core和logback-classic,以及如何通过logback.xml进行日志级别设置和输出位置控制。实例演示了如何创建Logger对象并记录日志信息。

1.日志概述

日志
用来记录程序运行过程中的信息,并可以进行永久存储。

日志技术应该具备哪些特点和优势
1.可以将系统执行的信息,方便的记录到指定的位置(控制台、文件中、数据库中)
2.可以随时以开关的形式控制是日志的记录和取消,无需进入到源代码中去进行修改;

在这里插入图片描述

2.日志技术体系、Logback概述

日志体系结构
在这里插入图片描述
Logback日志框架

官网:https://logback.qos.ch/index.html
http://www.slf4j.org/

Logback日志框架分为以下模块
logback-core: 该模块为其他两个模块提供基础代码。(必须有)
logback-classic: 完整实现了slf4j API的模块。(必须有)
logback-access: 与 Tomcat 和 Jetty 等 Servlet 容器集成,以提供 HTTP 访问日志功能。

想使用Logback日志框架,至少需要在项目中整合如下三个模块:
slf4j-api: 日志接口
logback-core: 基础模块
logback-classic: 功能模块,它完整实现了slf4j API

3.Logback快速入门

实现步骤

1.导入Logback框架到项目中去。在模块下新建文件夹lib,导入Logback的jar包到该文件夹下;
2.将存放jar文件的lib文件夹添加到项目依赖库中去;
3.将Logback的核心配置文件logback.xml直接拷贝到src目录下(必须是src下);
4.创建Logback框架提供的Logger日志对象,后续调用其方法记录系统的日志信息;
public static final Logger LOGGER = LoggerFactory.getLogger(“类名");

官网下载:https://logback.qos.ch/index.html
在这里插入图片描述在这里插入图片描述

Logback配置

对Logback日志框架的控制,都是通过核心配置文件logback.xml来实现的。

Logback日志输出位置、格式设置
通过logback.xml 中的标签可以设置输出位置,通常可以设置2个日志输出位置:一个是控制台、一个是系统文件中。

输出到控制台的配置标志

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

输出到系统文件的配置标志

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

Logback日志级别设置

<!--
    level:用来设置打印级别,大小写无关:TRACE < DEBUG < INFO < WARN < ERROR, ALL 和 OFF, 默认debug
    <root>可以包含零个或多个<appender-ref>元素,标识这个输出位置将会被本日志级别控制。
    -->
    <root level="ALL">
        <!--设置控制台输出-->
        <appender-ref ref="CONSOLE"/>  
        <!--设置在文件中输出-->
        <appender-ref ref="FILE" />
    </root>

示例配置

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <!--
        CONSOLE :表示当前的日志信息是可以输出到控制台的。
    -->
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <!--输出流对象 默认 System.out 改为 System.err-->
        <target>System.out</target>
        <encoder>
            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度
                %msg:日志消息,%n是换行符  %c:类名-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5level]  %c [%thread] : %msg%n</pattern>
        </encoder>
    </appender>

    <!-- File是输出的方向通向文件的 -->
    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
            <charset>utf-8</charset>
        </encoder>
        <!--日志输出路径-->
        <file>E:/Log/data.log</file>
        <!--指定日志文件拆分和压缩规则-->
        <rollingPolicy
                class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!--通过指定压缩文件名称,来确定分割文件方式-->
            <fileNamePattern>E:/Log/data-%d{yyyy-MMdd}.log%i.gz</fileNamePattern>
            <!--文件拆分大小-->
            <maxFileSize>1MB</maxFileSize>
        </rollingPolicy>
    </appender>

    <!--
    level:用来设置打印级别,大小写无关:TRACE < DEBUG < INFO < WARN < ERROR, ALL 和 OFF, 默认debug
    <root>可以包含零个或多个<appender-ref>元素,标识这个输出位置将会被本日志级别控制。
    -->
    <root level="ALL">
        <!--设置控制台输出-->
        <appender-ref ref="CONSOLE"/>
        <!--设置在文件中输出-->
        <appender-ref ref="FILE" />
    </root>

</configuration>

代码示例

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class Test {
    //定义日志对象
    public static final Logger LOGGER= LoggerFactory.getLogger("Test.java");
    public static void main(String[] args) {
        LOGGER.debug("main方法开始运行");

        try {
            LOGGER.trace("开始做除法");
            int a=10,b=0;
            LOGGER.info("a="+a);
            LOGGER.info("b="+b);
            int c=a/b;
        } catch (Exception e) {
            LOGGER.error("发生了异常:"+e);
        }

    }
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值