分享记录一个Log4j的踩坑配置

最近在日志打印的时候因为某类日志打印量特别大,体积又比较大,比较特殊需要分离,所以配置了一个独立的日志打印logger_B. 然后遇到一个小问题, 项目是个java springboot项目,部署在linux系统, 日志输出到独立logger_B生成的文件时, 也同步打印去了.out文件, 重复打印不说, 也导致out体积膨胀过快过大,造成比较大的不变.

这是独立logger的配置文件.

<logger name="logger_B" level="INFO" additivity="true">
  <appender-ref ref="logger_B_FILE"/>
</logger>

刚开始没发现是什么问题, 看了其他logger也是如此配置,没注意核对官方API,望文生义的以为 "additivity"是追加的意思. 后面经过某余同学指正, additivity是是否会在父Logger的appender里输出的意思。

官方API查证了下:

“Log4j中additivity的属性为true/false,它是子Logger 是否继承父Logger 的输出源(appender) 的标志位。具体说,默认情况下子Logger会继承父Logger的appender,也就是说子Logger会在父Logger的appender里输出。若是additivity设为false,则子Logger只会在自己的appender里输出,而不会在父Logger的appender里输出。"

小结

1. loj4j默认情况下additivity为true

2. 某个logger的additivity设置为false,表示log只打印到本log的appender中,而不再打印到其父logger的appender。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是一个详细的log4j2配置文件示例: ```xml <?xml version="1.0" encoding="UTF-8"?> <Configuration status="INFO"> <Appenders> <Console name="Console" target="SYSTEM_OUT"> <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" /> </Console> <RollingFile name="RollingFile" fileName="logs/app.log" filePattern="logs/app-%d{yyyy-MM-dd}.log.gz"> <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" /> <Policies> <TimeBasedTriggeringPolicy interval="1" modulate="true" /> <SizeBasedTriggeringPolicy size="10MB" /> </Policies> <DefaultRolloverStrategy max="10" /> </RollingFile> </Appenders> <Loggers> <Root level="INFO"> <AppenderRef ref="Console" /> <AppenderRef ref="RollingFile" /> </Root> </Loggers> </Configuration> ``` 该配置文件定义了两个Appenders(Console和RollingFile)以及一个Root Logger。Console Appender将日志输出到控制台,RollingFile Appender将日志输出到一个滚动的日志文件。RollingFile Appender使用了时间和大小两种触发策略,每天生成一个新的日志文件,并且日志文件最多保留10个。 Root Logger的日志级别为INFO,表示只输出INFO级别及以上的日志。Root Logger将日志输出到Console和RollingFile Appender中。 该配置文件的语法是基于XML的,其中Configuration元素是配置文件的根元素,定义了配置文件的一些全局属性,如status属性表示日志输出级别(DEBUG、INFO、WARN、ERROR)。Appenders元素定义了所有Appender,Loggers元素定义了所有Logger。每个Logger可以引用一个或多个Appender,以将日志输出到指定的位置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

it夜猫who

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值