Log4j2 xml文件按照项目启动环境命名demo
一,问题背景
项目中使用SpringBoot整合log4j2,并接入kafka发日志。项目有多个环境,local,dev,test,uat,prod。每个环境连接的kafka不一样,因此需要log4j2的配置文件按照启动的环境进行选择。
二,内容描述
log4j2读取配置文件顺序
log4j 2.x版本不再支持像1.x中的.properties后缀的文件配置方式,2.x版本配置文件后缀名只能为".xml",“.json"或者”.jsn"。系统选择配置文件的优先级(从先到后)如下:
(1).classpath下的名为log4j2-test.json 或者log4j2-test.jsn的文件。
(2).classpath下的名为log4j2-test.xml的文件。
(3).classpath下名为log4j2.json 或者log4j2.jsn的文件。
(4).classpath下名为log4j2.xml的文件。
————————————————
版权声明:本文为优快云博主「pan_junbiao」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.youkuaiyun.com/pan_junbiao/article/details/104313938
注意
如果项目中有 log4j2-test.xml 或 log4j2.xml命名的配置文件,则会优先使用这个,而不会按照对应环境的配置文件进行读取。
老实人写法
配置按照不同环境读取log4j2配置文件:
引入SpringBoot log4j2依赖
<dependency> <!-- 引入log4j2依赖 -->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
nacos或yml配置:
logging:
config: classpath:log4j2-${spring.profiles.active}log.xml
注意:
为什么要配置log4j2-${spring.profiles.active}log.xml,
而不是log4j2-${spring.profiles.active}.xml?
log4j2读取的顺序决定的。如果是test环境就GG了。
所以在环境后面加了一个【log】,当然这个可以随意加,看各自喜好
项目中classpath文件名称配置:
按照nacos中配置信息配置即可。
附本项目配置截图:
参考博客:
https://blog.csdn.net/sinat_37792529/article/details/122473617
推荐写法
nacos上配置:
logging:
config: classpath:log4j2-${spring.profiles.active}.xml
敲黑板了
针对test环境,增加application-test.yml配置文件,内容:
logging:
config: classpath:log4j2-testlog.xml
然后,配置文件classpath就要有对应的:
log4j2-testlog.xml