org.slf4j日志组件实现日志功能

slf4j 全称是Simple Logging Facade for Java。facade是一种设计模式。
slf4j 是一个抽象程度更高的日志组件,本身并不提供实际的日志功能。实际的日志功能是通过log4j等日志组件实现,而使用者只需要关心 slf4j 给出的API。
slf4j 仅仅是一个为Java程序提供日志输出的统一接口,并不是一个具体的日志实现方案,就比如JDBC一样,只是一种规则而已,
所以单独的slf4j是不能工作的,必须搭配其他具体的日志实现方案,比如log4j或者log4j2

slf4j-api提供了slf4j的抽象接口,我们作为使用者,只需要关心它提供的API就行。
slf4j-log4j12是slf4j与log4j的桥接组件。
log4j是我们常见的log4j日志组件。

Maven相关配置,会自动安装依赖 log4j-1.2.17

<!-- 日志相关 https://mvnrepository.com/artifact/org.slf4j/slf4j-api -->
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>1.7.30</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>1.7.25</version>
        </dependency>

需要补充配置文件:执行代码对应resources目录下

配置文件详细说明:

## 1 Level(Singe) file/Console (自动默认Level.DEBUG) =off,fatal,error、warn、info、debug
log4j.rootLogger=debug, stdout, file

Layout:日志输出格式,Log4j提供的layout有以下几种:
org.apache.log4j.HTMLLayout(以HTML表格形式布局),
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

# 2.1 输出到console
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
# %d   输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式-->2023-12-17 15:19:11 ,311
# %p   输出优先级,即 DEBUG,INFO,WARN,ERROR,FATAL-->DEBUG
# %c   输出所属的类目,通常就是所在类的全名-->com.cacho.s2b.lesson.learn.LearnLog
# %l   输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数-->com.cacho.s2b.lesson.learn.LearnLog.main(LearnLog.java:12)
# %L   输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数-->12=代码行数
# %m   输出代码中指定的消息-->真实打印的信息
# %r   输出自应用启动到输出该log信息耗费的毫秒数
# %n   输出一个回车换行符,Windows平台为“/r/n”,Unix平台为“/n”
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss ,SSS} %p %c:%l --> %m%n

# 2.2 输出到文件:
# 2.2.1 FileAppender(文件);
# 2.2.2 RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件);
    # 2.2.2.1 MaxBackupIndex=10-->指定可以产生的滚动文件的最大数10
    # 2.2.2.2 MaxFileSize=1M-->日志文件到达该大小时,将会自动生成新文件test1.log.1
# 2.2.3 DailyRollingFileAppender(每天产生一个日志文件);
    # 2.2.3.1 DatePattern='.'yyyy-MM-dd(默认每天一个文件);'.'yyyy-MM-dd-HH-mm(每分钟)
# 2.2.4 WriterAppender(将日志信息以流格式发送到任意指定的地方)
# 2.2.5 Append=false(默认值是true=将消息增加到指定文件中;false=将消息覆盖指定的文件内容)
log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.Encoding=UTF-8
log4j.appender.file.File=logs/test.log
log4j.appender.file.MaxFileSize=1kb
log4j.appender.file.MaxBackupIndex=10
log4j.appender.file. =org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %5p %c:%L --> %m%n

测试代码:

package com.cacho.s2b.lesson.learn;

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

/** @Description: slf4j-api=1.7.30 + slf4j-log4j12=1.7.25 + log4j=1.2.17
 * @Author LingWei
 * @date 2023/12/14
 **/
public class LearnLog {
    public static void main( String[] args ){
        String error = "error日志信息";
        String warn = "error日志信息";

        Logger logger = LoggerFactory.getLogger(LearnLog.class);
        logger.debug("slf4j项目使用了日志系统,这里是项目debug日志信息");
        logger.info("slf4j项目使用了日志系统,这里是项目info日志信息");
        logger.warn("slf4j项目使用了日志系统,这里是项目{}",warn);
        logger.error("slf4j项目使用了日志系统,这里是项目{}{}",error,":可以多个参数"); //{}替换成对应的变量值
    }
}

最终打印结果:

相关推荐

  1. 通过Slf4j中的MDC实现日志中添加用户IP功能

    2023-12-20 05:42:02       9 阅读
  2. log-01-日志组件之 Log4j 入门介绍

    2023-12-20 05:42:02       32 阅读
  3. spark log4j日志配置

    2023-12-20 05:42:02       29 阅读
  4. log4j日志框架的使用

    2023-12-20 05:42:02       33 阅读
  5. log4j日志打印配置

    2023-12-20 05:42:02       44 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-20 05:42:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-20 05:42:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-20 05:42:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-20 05:42:02       20 阅读

热门阅读

  1. 是的,决定放弃算法去机器学习了

    2023-12-20 05:42:02       40 阅读
  2. Unity工具栏介绍

    2023-12-20 05:42:02       35 阅读
  3. 深度比较(lodash 的 isEqual 方法)

    2023-12-20 05:42:02       40 阅读
  4. 通过fu过 Function Calling 查询数据库

    2023-12-20 05:42:02       34 阅读
  5. 普冉(PUYA)单片机开发笔记 [完结篇]:使用体会

    2023-12-20 05:42:02       48 阅读
  6. 高空作业MR混合现实情景实训教学应用

    2023-12-20 05:42:02       41 阅读
  7. 【算法小题 go程序版】递归练习 -- 猴子吃桃问题

    2023-12-20 05:42:02       40 阅读
  8. 链式表的实现

    2023-12-20 05:42:02       32 阅读
  9. Docker使用7-Use Docker Compose

    2023-12-20 05:42:02       56 阅读
  10. 【嵌入式面试】嵌入式经典面试题汇总(C语言)

    2023-12-20 05:42:02       34 阅读