SpringBoot中整合log4j2

第1步:依赖引入

引入log4j2的依赖spring-boot-starter-log4j2 并排除掉logback日志框架的依赖spring-boot-starter-logging

<!--log4j2-->
<!-- 排除 Spring-boot-starter 默认的日志配置 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
    <exclusions>
        <exclusion>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-logging</artifactId>
        </exclusion>
    </exclusions>
</dependency>
<!-- 引入log4j2依赖 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>

第2步:指定log4j2配置文件路径

通常在classpath下添加。如果不想把配置放到classpath下,可以在配置文件自定义位置

# 默认路径 : log4j2.xml 默认放在 src/main/resources 目录下
logging:
  config: classpath:log4j2.xml

# 自定义位置:需明确指定
logging:
  config: /home/userA/SpringBoot/config/log4j2.xml

[Ref] SpringBoot 2.x整合Log4j2日志
[Ref] SpringBoot—整合log4j2入门和log4j2.xml配置详解


第3步:log4j.xml 样例

<?xml version="1.0" encoding="UTF-8"?>
<configuration status="info" monitorInterval="10">

    <properties>
        <property name="LOG_HOME">./applog/logs</property>
        <Property name="FILE_NAME" value="practisesvr"/>
        <Property name="LOG_PATTERN" value="[%d{yyyy-MM-dd HH:mm:ss}] [%-5level] [%thread] [%file:%line] → [%m]%n"/>
        <!--        <Property name="LOG_PATTERN" value="[%d{yyyy-MM-dd HH:mm:ss}] [%-5level] [%thread] [%file:%line] → [%enc{%m}{CRLF}]%n"/>-->
        <!--        <Property name="LOG_PATTERN" value="[%d{yyyy-MM-dd HH:mm:ss.SSSSSS}] [%-5p] [%thread] [%file:%line] → [%replace{%enc{%m}{CRLF}}{\\r|\\n|%0D|%0A|%0a|%0d}{}]%n"/>-->
    </properties>

    <appenders>
        <console name="CONSOLE" target="SYSTEM_OUT">
            <PatternLayout pattern="${LOG_PATTERN}"/>
            <Filters>
                <ThresholdFilter level="error" onMatch="DENY" onMismatch="NEUTRAL"/>
                <ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY"/>
            </Filters>
        </console>

        <File name="LOG_FILE"
              fileName="${LOG_HOME}/appendLog.log"
              append="true">
            <PatternLayout pattern="${LOG_PATTERN}"/>
            <ThresholdFilter level="WARN" onMatch="ACCEPT" onMismatch="DENY"/>
        </File>

        <RollingFile name="api_json"
                     fileName="${LOG_HOME}/${FILE_NAME}.log"
                     filePattern="${LOG_HOME}/${FILE_NAME}_%d{yyyy-MM-dd-HH}_%i.log.gz"
                     createOnDemand="true">
            <ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY"/>
            <PatternLayout pattern="${LOG_PATTERN}"/>
            <Policies>
                <SizeBasedTriggeringPolicy size="100K"/>
            </Policies>
            <DefaultRolloverStrategy fileIndex="nomax">
                <Delete basePath="${LOG_HOME}" maxDepth="2">
                    <IfFileName glob="*.log.gz">
                        <IfAny>
                            <IfAccumulatedFileSize exceeds="100M"/>
                            <IfAccumulatedFileCount exceeds="100"/>
                            <IfLastModified age="30d"/>
                        </IfAny>
                    </IfFileName>
                </Delete>
            </DefaultRolloverStrategy>
        </RollingFile>

        <RollingFile name="storage_check"
                     fileName="${LOG_HOME}/storage_check.log"
                     filePattern="${LOG_HOME}/storage_check_%d{yyyy-MM-dd-HH}_%i.log.gz"
                     createOnDemand="true">
            <PatternLayout pattern="${LOG_PATTERN}"/>
            <Policies>
                <SizeBasedTriggeringPolicy size="1M"/>
            </Policies>
            <DefaultRolloverStrategy fileIndex="nomax">
                <Delete basePath="${LOG_HOME}" maxDepth="2">
                    <IfFileName glob="*.log.gz">
                        <IfAny>
                            <IfAccumulatedFileSize exceeds="10M"/>
                            <IfAccumulatedFileCount exceeds="100"/>
                            <IfLastModified age="30d"/>
                        </IfAny>
                    </IfFileName>
                </Delete>
            </DefaultRolloverStrategy>
        </RollingFile>
    </appenders>

    <loggers>
        <root level="all">
            <AppenderRef ref="CONSOLE"/>
            <AppenderRef ref="LOG_FILE"/>
        </root>

        <logger name="com.zhangziwa.practisesvr.utils.log.logUtils" level="info" additivity="false">
            <AppenderRef ref="CONSOLE"/>
            <AppenderRef ref="api_json"/>
        </logger>
        <logger name="com.zhangziwa.practisesvr.utils.task.StorageHealthyCheckTask" level="info" additivity="false">
            <AppenderRef ref="CONSOLE"/>
            <AppenderRef ref="storage_check"/>
        </logger>
    </loggers>
</configuration>

第4步:业务使用

import lombok.extern.log4j.Log4j2;

@Log4j2
public class Log4jTest {
    public static void main(String[] args) throws InterruptedException {
        int i = 1;
        while (true) {
            Thread.sleep(1000);
            log.trace("这是测试trace" + i);
            log.debug("这是测试debug" + i);
            log.info("这是测试info" + i);
            log.warn("这是测试warn" + i);
            log.error("这是测试error" + i);
            log.fatal("这是测试fatal" + i);
            i++;
        }
    }
}

在这里插入图片描述

参考

[Ref] Springboot整合log4j2(按级别拆分)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Spring Boot 2.1.5使用Log4j2,需要进行以下步骤: 1. 在 `pom.xml` 文件添加Log4j2的依赖: ```xml <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-slf4j-impl</artifactId> <version>2.11.2</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-core</artifactId> <version>2.11.2</version> </dependency> ``` 2. 在 `src/main/resources` 目录下创建一个名为 `log4j2.xml` 的配置文件,内容如下: ```xml <?xml version="1.0" encoding="UTF-8"?> <Configuration status="WARN"> <Appenders> <Console name="Console" target="SYSTEM_OUT"> <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/> </Console> </Appenders> <Loggers> <Root level="info"> <AppenderRef ref="Console"/> </Root> </Loggers> </Configuration> ``` 这个配置文件指定了日志输出的格式和级别,以及将日志输出到控制台。 3. 在Spring Boot的启动文件(一般是 `Application.java` 文件),添加注解 `@EnableAsync`、`@EnableScheduling` 和 `@EnableAspectJAutoProxy`,并在类添加一个名为 `logger` 的静态字段,代码如下: ```java import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.scheduling.annotation.EnableAsync; import org.springframework.scheduling.annotation.EnableScheduling; import org.springframework.transaction.annotation.EnableTransactionManagement; @SpringBootApplication @EnableAsync @EnableScheduling @EnableAspectJAutoProxy(proxyTargetClass = true) @EnableTransactionManagement public class Application { private static final Logger logger = LoggerFactory.getLogger(Application.class); public static void main(String[] args) { SpringApplication.run(Application.class, args); logger.info("Spring Boot started."); } } ``` 在这里,我们使用了 `LoggerFactory.getLogger` 方法创建了一个名为 `logger` 的静态字段,并在应用启动后输出了一条日志信息。 现在,你可以在应用使用 `logger` 字段来记录日志了,比如: ```java logger.info("This is an info message."); logger.error("This is an error message.", exception); ``` Log4j2会根据你在 `log4j2.xml` 的配置将日志输出到控制台。如果你想将日志输出到文件,可以在 `log4j2.xml` 添加一个 `FileAppender`。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值