日志技术-Logback

日志技术

  • 将系统执行的信息,方便的记录到指定位置(控制台、文件、数据库)
  • 可以随时以开关的形式开关日志,无需入侵到源代码去修改

    日志接口:设计日志框架的统一标准
    注:有人对JCL接口不满意,就有了SLF4J。有人对log4j性能不满意,就有了LogBack,LogBack是基于SLF4J开发的

依赖:

下载:下载时注意不同版本JDK不同

  • logback-classic-1.3.8.jar
  • logback-core-1.3.8.jar
  • slf4j-api-2.0.3.jar

配置文件 logback.xml(src下)

java 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <!-- CONSOLE :表示当前的日志信息是可以输出到控制台的 -->
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <!--输出流对象 默认 System.out 改为 System.err  其中err:控制台输出日志为红色,而out为黑色-->
        <target>System.out</target>
        <encoder>
            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度 %msg:日志消息,%n是换行符-->
            <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>
        <!--日志输出路径(output.log是文档名,下方还有一处文件名(不用写.log))-->
        <file>D:/output.log</file>
        <!--指定日志文件拆分和压缩规则(防止文件过大)-->
        <rollingPolicy
                class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!--通过指定压缩文件名称,来确定分割文件方式-->
            <fileNamePattern>D:/output-%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="INFO"> <!--打印规则:只打印不低于当前级别的日志-->
        <appender-ref ref="CONSOLE"/> <!--如果这个地方不配置关联打印的位置,改位置将不会记录日志-->
        <appender-ref ref="FILE"/>
    </root>
</configuration>

使用

java 复制代码
public class Test {

    public static  final Logger LOGGER=LoggerFactory.getLogger(Test.class);
    public static void main(String[] args) {
            LOGGER.info("11111111");
            try {
                LOGGER.debug("debug");
                LOGGER.warn("warn");
            int i=1/0;


            }catch (Exception e){
            LOGGER.error("测试");
            }
    }
}
相关推荐
EumenidesJ8 小时前
Java常用日志框架介绍
java·log4j·logback·slf4j
躲在没风的地方10 天前
logback日志控制服务器日志输出
java·服务器·logback
ta叫我小白14 天前
Spring Boot 设置滚动日志logback
java·spring boot·spring·logback
代码的余温17 天前
Spring Boot集成Logback日志全攻略
xml·spring boot·logback
代码的余温17 天前
Logback.xml配置详解与实战指南
xml·logback
清风920018 天前
Logback——日志技术(基础)
java·前端·logback
代码的余温18 天前
MyBatis集成Logback日志全攻略
java·tomcat·mybatis·logback
秋千码途20 天前
小架构step系列08:logback.xml的配置
xml·java·logback
枣伊吕波23 天前
第十五节:第六部分:日志技术:logback的核心配置文件详解、日志级别
logback
再见晴天*_*24 天前
logback 日志不打印
java·服务器·logback