log4j 2按照下面优先级由高到低的顺序查找使用日志的配置:
1、系统变量log4j2.configurationFile中指明的配置文件;
2、类路径上的log4j2-test.properties配置文件;
3、类路径上的log4j2-test.yaml 或者 log4j2-test.yml配置文件;
4、类路径上的log4j2-test.json 或者 log4j2-test.jsn配置文件;
5、类路径上的log4j2-test.xml配置文件;
6、类路径上的log4j2.properties配置文件;
7、类路径上的log4j2.yaml 或者 log4j2.yml配置文件;
8、类路径上的log4j2.json 或者 log4j2.jsn配置文件;
9、类路径上的log4j2.xml配置文件;
10、如果上面的配置文件都没有找到,就使用默认配置DefaultConfiguration,默认配置为:
1)一个ConsoleAppender绑定到root logger
2)一个PatternLayout绑定到ConsoleAppender,输出形式为"%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"
3)默认配置root logger的日志级别为Level.ERROR。可以使用系统属性org.apache.logging.log4j.level修改默认配置的日志级别。
采用默认配置日志的输出样例:
英文请参考:
https://logging.apache.org/log4j/2.x/manual/configuration.html
https://logging.apache.org/log4j/2.x/javadoc/log4j-core/index.html
在maven工程中,如果是本地系统,log4j 2的配置文件可以放在src/main/resources目录下,例如,有一个配置文件log4j2.xml: