原文: https://howtodoinjava.com/log4j2/log4j2-properties-example/
学习配置log4j2.properties文件,以将日志语句输出到控制台,滚动文件等。学习配置 log4j2 附加器,级别和模式。
Apache Log4j2 是 Log4j 1.x 的升级版,对它的前身进行了重大改进,例如性能提高,自动重新加载已修改的配置文件, Java8 lambda 支持和自定义 日志级别。
1. Log4j2 Maven 依赖项
要包含 Log4j2 ,请在项目中包含以下 maven 依赖项。
<dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-api</artifactId><version>2.6.1</version></dependency><dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-core</artifactId><version>2.6.1</version></dependency>
2. log4j2.properties – 控制台日志记录
我们可以使用下面的log4j2.properties文件将日志输出到控制台。 请注意,如果找不到配置文件,则将使用DefaultConfiguration。 Log4j2 默认日志记录还将日志输出到控制台。
status = errorname = PropertiesConfigfilters = thresholdfilter.threshold.type = ThresholdFilterfilter.threshold.level = debugappenders = consoleappender.console.type = Consoleappender.console.name = STDOUTappender.console.layout.type = PatternLayoutappender.console.layout.pattern = %d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%nrootLogger.level = debugrootLogger.appenderRefs = stdoutrootLogger.appenderRef.stdout.ref = STDOUT
3. log4j2.properties – 滚动文件附加器
我们可以使用下面的log4j2.properties文件将日志输出到基于日期的滚动文件。
status = errorname = PropertiesConfig#Make sure to change log file path as per your needproperty.filename = C:\\logs\\debug.logfilters = thresholdfilter.threshold.type = ThresholdFilterfilter.threshold.level = debugappenders = rollingappender.rolling.type = RollingFileappender.rolling.name = RollingFileappender.rolling.fileName = ${filename}appender.rolling.filePattern = debug-backup-%d{MM-dd-yy-HH-mm-ss}-%i.log.gzappender.rolling.layout.type = PatternLayoutappender.rolling.layout.pattern = %d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%nappender.rolling.policies.type = Policiesappender.rolling.policies.time.type = TimeBasedTriggeringPolicyappender.rolling.policies.time.interval = 1appender.rolling.policies.time.modulate = trueappender.rolling.policies.size.type = SizeBasedTriggeringPolicyappender.rolling.policies.size.size=10MBappender.rolling.strategy.type = DefaultRolloverStrategyappender.rolling.strategy.max = 20loggers = rolling#Make sure to change the package structure as per your applicationlogger.rolling.name = com.howtodoinjavalogger.rolling.level = debuglogger.rolling.additivity = falselogger.rolling.appenderRef.rolling.ref = RollingFile
4. log4j2.properties文件路径
我们应该将log4j2.properties放在应用的类路径中的任何位置。 Log4j2 将扫描所有类路径位置以查找此文件,然后将其加载。

Log4j2.properties文件位置
5. log4j2 属性文件示例
让我们写一个 Java 类并写一些日志语句来验证日志是否也出现在控制台和日志文件中。
package com.howtodoinjava.log4j2.examples;import org.apache.logging.log4j.LogManager;import org.apache.logging.log4j.Logger;public class Log4j2HelloWorldExample{private static final Logger LOGGER = LogManager.getLogger(Log4j2HelloWorldExample.class.getName());public static void main(String[] args){LOGGER.debug("Debug Message Logged !!!");LOGGER.info("Info Message Logged !!!");LOGGER.error("Error Message Logged !!!", new NullPointerException("NullError"));}}
现在,当您运行上述程序时,您将在控制台中获得以下日志。
2016-06-16 13:41:27 DEBUG Log4j2HelloWorldExample:12 - Debug Message Logged !!!2016-06-16 13:41:27 INFO Log4j2HelloWorldExample:13 - Info Message Logged !!!2016-06-16 13:41:27 ERROR Log4j2HelloWorldExample:14 - Error Message Logged !!!java.lang.NullPointerException: NullErrorat com.howtodoinjava.log4j2.examples.Log4j2HelloWorldExample.main(Log4j2HelloWorldExample.java:14)[classes/:?]
学习愉快!
