关于遍历服务每次启动生成新的日志文件的逻辑

背景

最近遍历服务遇到一个问题, 由于遍历服务是以jar的形式提供给到其他调用方使用的,所以有可能会存在说一个服务中,可能会起来多个进程调用。然后遍历服务的日志使用的是log4j的框架,默认的配置会出现所有的进程的日志都会打到同一个日志文件中,这个就导致了我们在分析问题的时候就非常的被动,因为没有办法很快的分析都对应的某一台设备的上下文的日志了。

解决

研究了好久以后, 终于找到了解决方法 : log4j2配置文件动态指定日志文件名称, 这篇文章中给提供了思路,可以通过系统环境变量的方式,就可以动态去指定日志文件的名称了。所以我们要做的就是在启动jar的时候,声明好变量。例如这样子的调用

java -Dlog4fFile=test -jar vendor/appcrawler-java-1.0.jar

这样子,我们就可以在log4j2的配置文件里面这样子声明我们的日志文件名称就可以完美解决了。

# 配置logfile输出到文件中 文件大小到达指定尺寸的时候产生新的日志文件
log4j.appender.logfile=org.apache.log4j.RollingFileAppender
# 保存编码格式
log4j.appende
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值