首页 > 编程语言 >java日志之log4j、log4j2、slf4j以及整合关系

java日志之log4j、log4j2、slf4j以及整合关系

时间:2022-11-22 09:45:16浏览次数:59  
标签:logger java slf4j apache org Logger log4j2 log4j

了解log4j、log4j2之间的关系;以及与slf4j整合时使用的中间jar包:slf4j-log4j12、log4j-slf4j-impl。

  • 1.Log4j

  • log4j核心包只有一个,即log4j.jar。上图是log4j最后的版本,版本号是1.2

    包名:org.apache.log4j

    配置文件是一个.properties的文件

    调用方式:

  • import org.apache.log4j.Logger;

  • Logger logger= Logger.getLogger(Test.class);

  • logger.info("aaa");

  • 接着就是log4j2横空出世了
  • 2.log4j2

  •  

     

     

    log4j2的核心包有两个,分别是log4j-api和log4j-core。

    包名:org.apache.logging.log4j

    配置文件采用的是.xml

    调用方式:

    import org.apache.logging.log4j.LogManager;
    import org.apache.logging.log4j.Logger;

    private static Logger logger= LogManager.getLogger(Test.class.getName());
    logger.info("aaa");

    3.与slf4j整合


    3.1 Log4j与slf4j整合
    整合所需jar包:

    <dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.10</version>
    </dependency>

    <dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
    <version>1.7.0</version>
    </dependency>
    <dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
    </dependency>
    调用方式:

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

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

    logger.info("aaa");
    补充:slf4j-log4j12.jar名字中的log4j指的是log4j,12应该是与log4j的终版1.2版本有关系(本人猜测)

    3.2 Log4j2与slf4j整合
    整合所需jar包:

    <dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-api</artifactId>
    <version>2.2</version>
    </dependency>
    <dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>2.2</version>
    </dependency>

    <dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-slf4j-impl</artifactId>
    <version>2.1</version>
    </dependency>

    <dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.7</version>
    </dependency>
    调用方式:同3.1的调用方式
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;

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

    logger.info("aaa");
    总结:3.1与3.2相比,都是使用slf4j的接口,所以调用方式一样,只是底层用的是不同的log实现

  • 4.jar包说明

    与slf4j整合时使用的jar:slf4j-log4j12(log4j)、log4j-slf4j-impl(log4j2)

    包名的不同,说明他们由不同的组织维护,不同的组织反映了中间Jar命名的混乱现象(个人猜测)。

  •  

     

     

     

     

标签:logger,java,slf4j,apache,org,Logger,log4j2,log4j
From: https://www.cnblogs.com/liftsail/p/16914153.html

相关文章

  • Java工具库Guava并发相关工具类的使用示例
    场景Java核心工具库Guava介绍以及Optional和Preconditions使用进行非空和数据校验:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/127683387Java中Executo......
  • Java NIO编程实例
     文章目录前言一、NIO与BIO的比较二、Buffer的机制及其子类1.Buffer的使用2.Buffer的四个基本类型三、Channel的使用1.Channel的特征2.Channel的子......
  • java学习
     一、前言1、JRE和JDKJREJava程序的运行环境,包含JVM(Java虚拟机)和运行时所需要的核心类库JDKJava程序开发工具包,包含JRE和开发人员使用的工具(编译工具:javac.ex......
  • Java - HuTool工具的介绍与使用(总)
    本篇主要介绍HuTool工具,其是java工具类,对于一些静态方法进行封装,虽然很小,但很全,里面拥有平时我们会用到的工具类,就无需我们自己去封装了以前我还自己去封装,emmm,我真的......
  • Java Swing 学习记录
    目录参考资料什么是Swing?Swing和AWTSwing组件1JFrame窗口2JPanel面板3LayoutManager布局管理器3.1边框布局管理器3.2流式布局管理器3.3卡片布局管理器3.4网......
  • Javac编译器
    Javac编译器Java技术下的编译期在不同的语境下会有不同的编译器实现产品:1、前端编译器:jdk的javac、EclipseJDT中的增量式编译器2、即时编译器:hotspot虚拟机中的c1、c2......
  • java15源码-ThreadPoolExecutor
    一Executors工具类创建ThreadPoolExecutorSingleThreadExecutornewFixedThreadPoolnewCachedThreadPoolnewScheduledThreadPoolnewSingleThreadScheduledExecuto......
  • JAVA-动漫美女拼图游戏
    代码1packagecom.itheima_02;publicclassApp{publicstaticvoidmain(String[]args){PictureFramepf=newPictureFrame();}}代码2p......
  • 【Java】Redis保存Java对象
    1.前言这是一篇来自2018年的文章,当时已经在现在这家公司工作。公司刚起步是购买外包公司产品做定制化开发,在开发微信版的过程中遇到了一个问题。由于微信端需要通过H5的入......
  • Java自定义类加载器
    通过继承java.lang.ClassLoader可以自定义类加载器。步骤:1、继承ClassLoader。2、读取字节文件到字节数组中。3、使用defineClass(类名,字节数组,off,length):将字节数组转换......