log4j中logger标签中additivity属性的用法说明

网友投稿 1152 2022-11-12

log4j中logger标签中additivity属性的用法说明

log4j中logger标签中additivity属性的用法说明

目录log4j logger标签中additivity属性log4j.additivity用法和例子

log4j logger标签中additivity属性

将logger中的 additivity 属性配置为 false,则这个logger不会将日志流反馈到root中。

可以达到以logger中配置的appender方式来输出日志而其他地方输出的目的,看配置:

< appender name = "DEMO" class = "com.XXXXX.RollingFileAppender" >

< param name = "file" value = "${loggingRoot}/xxx.log" />

< param name = "append" value = "true" />

< param name = "encoding" value = "GB2312" />

< param name = "threshold" value = "info" />

< param name = "MaxFileSize" value = "50MB" />

< param name = "MaxBackupIndex" value = "10" />

< layout class = "org.apache.log4j.PatternLayout" >

< param name = "ConversionPattern" value = "%d [%X{requestURIWithQueryString}] %-5p %c{2} - %m%n" />

&lthttp://;/ lNyDTRVtlRQayout >

appender >

< logger name = "XXXX.XXXX.XXXX" additivity = "false" >

< level value = "${loggingLevel}" />

< appender-ref ref = "DEMO" />

logger >

root的作用是收集下面所有反馈上来的信息流并根据配置在root中appender进行输出,只要你http://在looger中配置了additivity="false",就不会反馈到root中。

意味着不会重复输出!

log4j.additivity用法和例子

因为需要将packageOne和packageTwo的日志写入各自单独的文件,同时在总的日志中不出现packageOne和PackageTwo的日志。

可以使用log4j.additivity。因为log4j是层次的,如果没有log4j.additivity默认写入到packageOneFileAppender和packageTwoFileAppender的都会写入rootLogger的rootFileAppender

log4j.logger.com.demo.packageOone = INFO, packageOneFileAppender

log4j.additivity.com.demo.

packageOne

= false

log4http://j.category.com.demo.packageTwo = INFO, packageTwoFileAppender

log4j.additivity.com.demo.packageTwo = false

log4j.rootLogger = INFO, rootFileAppender

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:C++核心准则C.120:类层次体系只用于表现固有的阶层结构‍
下一篇:C++核心准则C.122:需要完全隔离接口和实现时用抽象类作为接口‍
相关文章

 发表评论

暂时没有评论,来抢沙发吧~