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
和马文依赖,
<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
和我的马文依赖,
<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
应用程序中,会生成一个文件,但它保持为空。我看到相同的最终登录控制台。此外,属性中的layout.pattern
似乎不会影响任何事情。
注意:使用 Slf4j
关于写入文件,您应该检查文档:
默认情况下,Spring 引导只会记录到控制台,不会 写入日志文件。如果要写入日志文件以及 控制台输出 您需要设置 logging.file 或 logging.path 属性 (例如,在您的应用程序属性中)。