从log4j迁移到lof4j2时出现SpringBoot问题

时间:2016-03-18 10:56:15

标签: java spring spring-boot log4j2

BEFORE(工作正常)

log4j.properties

log4j.rootLogger=DEBUG, file

log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=logs/spring-boot-mqtt.log
log4j.appender.file.MaxFileSize=5MB
log4j.appender.file.MaxBackupIndex=10
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=[%d{yyyy-MM-dd HH:mm:ss:SSS}] [%-5p] [%t] [%c{1}] - %m%n

和maven依赖,

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

之后(没有工作)

log4j2.properties

name = PropertiesConfig
property.filename = logs
appenders = file

appender.file.type = File
appender.file.name = ROLLING
appender.file.append = true
appender.file.fileName=${filename}/spring-boot-mqtt.log
appender.file.layout.type=PatternLayout
appender.file.layout.pattern=[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%-5p] [%t][%c{2}] - %m%n

rootLogger.level = debug
rootLogger.appenderRefs = file
rootLogger.appenderRef.file.ref = ROLLING

和我的maven依赖,

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-log4j2</artifactId>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
        <version>2.5</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
        <version>2.5</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-slf4j-impl</artifactId>
        <version>2.5</version>
    </dependency>

当我在独立的Java应用程序中对log4j2使用相同的配置时,它可以正常工作。但是在spring-boot应用程序中,会生成一个文件但它保持为空。我在控制台中看到相同的defualt登录。此外,layout.pattern属性似乎不会影响任何内容。

注意:使用Slf4j

1 个答案:

答案 0 :(得分:1)

关于写入文件,您应该检查documentation

  

默认情况下,Spring Boot只会登录到控制台而不会   写日志文件。如果你想写除日志文件   控制台输出需要设置logging.file或logging.path属性   (例如在你的application.properties中)。