Log4j2 xml文件按照项目启动环境命名demo

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值