Java log4j2 使用小结-quick start

日志在我们日常开发中必不可少,在各种项目中,通过日志记录各种信息,比如典型的 web 应用,通常我们都会记录下 请求和响应,有的时候对于一些关键的处理逻辑,我们也会记录,以便在排查问题时快速定位。

今天我们就 Java 项目中常用的日志框架 log4j2 做个使用小结,其实也是个 quick start,log4j2 日志框架强大,就几篇分享肯定搞不定,后续有时间再学习下相关的内容。

闲话少说,我们直接看看在一个 maven项目管理 中,我们是怎么使用 log4j2 的吧。

1.创建 maven项目

创建 maven项目都是比较简单了,直接在 IDEA 中创建即可。

这是我的 maven项目:

2.编写依赖

接下来是编写项目依赖,因为我们用到 log4j2,对应会依赖 log4j-apilog4j-core,所以我们在pom.xml中加入下面依赖部分:

xml 复制代码
<dependencies>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
        <version>2.21.1</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
        <version>2.21.1</version>
    </dependency>
</dependencies>

以下是 pom.xml 的完整内容:

xml 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.example</groupId>
    <artifactId>log4j2Demo</artifactId>
    <version>1.0-SNAPSHOT</version>

    <properties>
        <maven.compiler.source>21</maven.compiler.source>
        <maven.compiler.target>21</maven.compiler.target>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

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

</project>

3.编写log4j2配置

接下来是配置 log4j2,在 resources目录 下新建 log4j2.xml,建议这样命名,下面日志配置的内容:

xml 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="INFO">
    <Appenders>
        <Console name="console" target="SYSTEM_OUT">
            <PatternLayout pattern="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
        </Console>
        <File name="file" fileName="logs/app.log">
            <PatternLayout pattern="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
        </File>
    </Appenders>
    <Loggers>
        <Root level="debug">
            <AppenderRef ref="console"/>
            <AppenderRef ref="file"/>
        </Root>
    </Loggers>
</Configuration>

从配置中,我们主要关注两个标签,一个是 Appenders,一个是 Loggers,在 Appenders 中,我们加入两项输出,一个是控制台,一个是文件,所以只要有日志打印,对应的输出到控制台和文件中。

这里需要注意一点: 我们在选择输出到文件时,指定了日志存储路径,实际这个 logs目录 应该在项目的根目录中先创建好,具体文件系统会自动创建。

4.项目中使用

接下来是项目中的应用:

Java 复制代码
package org.example;

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

public class MyHelloWorld {
    private static Logger logger = LogManager.getLogger(MyHelloWorld.class);

    public static void main(String[] args) {
        logger.debug("这是 DEBUG 日志");
        logger.info("这是 INFO 日志");
        logger.error("这是 ERROR 日志");
        logger.fatal("这是 FATAL 日志");
    }
}

运行下 main,check下在控制台和文件汇总是否都有输出。

console

less 复制代码
2023-11-16 17:21:36,245 DEBUG [main] example.MyHelloWorld (MyHelloWorld.java:10) - 这是 DEBUG 日志
2023-11-16 17:21:36,248 INFO  [main] example.MyHelloWorld (MyHelloWorld.java:11) - 这是 INFO 日志
2023-11-16 17:21:36,249 ERROR [main] example.MyHelloWorld (MyHelloWorld.java:12) - 这是 ERROR 日志
2023-11-16 17:21:36,249 FATAL [main] example.MyHelloWorld (MyHelloWorld.java:13) - 这是 FATAL 日志

logs/app.log

通过以上的小case,我们实现了 log4j2 在项目中使用,最后总结下:

  • 1.编写 pom.xml 项目依赖
  • 2.编写 log4j2 配置 log4j2.xml
  • 3.项目中应用 log4j
相关推荐
Java技术小馆5 分钟前
GitDiagram如何让你的GitHub项目可视化
java·后端·面试
星星电灯猴29 分钟前
iOS 性能调试全流程:从 Demo 到产品化的小团队实战经验
后端
程序无bug38 分钟前
手写Spring框架
java·后端
JohnYan40 分钟前
模板+数据的文档生成技术方案设计和实现
javascript·后端·架构
全干engineer1 小时前
Spring Boot 实现主表+明细表 Excel 导出(EasyPOI 实战)
java·spring boot·后端·excel·easypoi·excel导出
Da_秀1 小时前
软件工程中耦合度
开发语言·后端·架构·软件工程
蓝易云1 小时前
Qt框架中connect()方法的ConnectionType参数使用说明 点击改变文章字体大小
linux·前端·后端
a_Dragon11 小时前
Spring Boot多环境开发-Profiles
java·spring boot·后端·intellij-idea
用户8324951417321 小时前
Maven 项目打包:实现业务代码与第三方依赖分离
后端
发仔1231 小时前
解析实时推荐系统的数据流向
后端