如何为SpringBoot添加滚动文件记录器?

问题描述 投票:0回答:1

我正在使用这个非常好的例子学习SpringBoot。此处.

但有一件事我想学习如何添加到这个项目中,就是 RollingFileAppender.

在我以前的项目中,我总是做以下工作。

1) 添加这些依赖关系

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

2) 添加以下文件 log4j.propertiessrc/main/resources 文件夹。

# Root logger option
log4j.rootLogger=INFO, stdout, loggerId

log4j.appender.loggerId=org.apache.log4j.RollingFileAppender  
log4j.appender.loggerId.layout=org.apache.log4j.PatternLayout  
log4j.appender.loggerId.layout.ConversionPattern=%d [%t] %-5p (%F:%L) - %m%n  
log4j.appender.loggerId.File=logs/app.log
log4j.appender.loggerId.MaxFileSize=100MB
log4j.appender.loggerId.MaxBackupIndex=30

# Direct log messages to stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

# Silence unnecessary logs
log4j.logger.net.schmizz=OFF
log4j.logger.io.javalin=OFF
log4j.logger.net.dv8tion.jda.core.requests=OFF

3)在代码中,我可以直接调用记录器。

private Logger LOG = LoggerFactory.getLogger(<class>)

(...)

LOG.info("logging a message")

这样就可以把日志传到控制台,并传到一个叫做 logs/app.log 最大大小为100MB(定义在属性文件中)。

在现代的SpringBoot项目中,比如我在GitHub上链接的项目,正确的方法是什么,可能是使用SpringBoot自带的记录器?

谢谢!我在学习SpringBoot时,使用的是GitHub中的SpringBoot自带的记录器。

spring spring-boot logging log4j slf4j
1个回答
1
投票

在Spring Boot中的日志记录与在vanilla Java项目中的日志记录并没有本质上的不同。Spring Boot使用Commons Logging进行所有内部日志记录,但对底层日志实现保持开放。为Java Util Logging、Log4J2和Logback提供了默认配置。在每种情况下,日志记录器都被预先配置为使用控制台输出,也可选择文件输出。默认情况下,如果使用 "启动器",则使用Logback进行日志记录。1

如果你想坚持使用 Log4J2,你必须排除默认的 Logback 依赖,并包含 Log4J2。

<!-- exclude logback , add log4j2 -->
<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>

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>

然后添加一个新文件,叫做 log4j2.xml 或(log4j2.properties)在 src/main/resources

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <appender name="loggerId" class="org.apache.log4j.RollingFileAppender">
        <param name="File" value="logs/app.log"/>
        <param name="MaxBackupIndex" value="30"/>
        <param name="MaxFileSize" value="100MB"/>
        <layout class="org.apache.log4j.PatternLayout  ">
            <param name="ConversionPattern" value="%d [%t] %-5p (%F:%L) - %m%n"/>
        </layout>
    </appender>
    <appender name="stdout" class="org.apache.log4j.ConsoleAppender">
        <param name="Target" value="System.out"/>
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n"/>
        </layout>
    </appender>
    <logger name="io.javalin">
        <level value="OFF"/>
    </logger>
    <logger name="net.dv8tion.jda.core.requests">
        <level value="OFF"/>
    </logger>
    <logger name="net.schmizz">
        <level value="OFF"/>
    </logger>
    <root>
        <level value="INFO"/>
        <appender-ref ref="stdout"/>
        <appender-ref ref="loggerId"/>
    </root>
</configuration>

欲了解更多信息: baeldung.com 是我的首选之地,可以找到关于如何做这些东西的好的重点教程。既然你是专门询问关于滚动文件贴标器的建议,我推荐你看一下 滚动文件附加器指南. 还有一篇更通用的文章 登录Spring Boot.

就个人而言,我喜欢用 龙目岛注释 喜欢 @Slf4j 以摆脱记录的模板,防止复制和粘贴错误。

代码上

© www.soinside.com 2019 - 2024. All rights reserved.