前言

接管了别的项目组的一个代码,在IDAE调试程序过程中,发现log4j日志居然没有打印控制台上,日志相关代码没有问题

网上搜索了一圈,总结了一下个人解决这个问题流程

流程

1. 判断用了什么配置文件

知道是出于什么目的,项目中居然有log4j的propertiesxml两个配置文件

刚开始我都没有看到xml文件,一直在关注properties文件,发现也没啥问题。后来在Vm options添加了**-Dlog4j.debug**,在启动打印log4j的信息发现log4j用的是xml文件。

2. additivity

其次就是<logger>的additivity属性

<!-- 打印控制台 -->
<appender name="myConsole" class="org.apache.log4j.ConsoleAppender">
   <param name="Target" value="System.out" />
   <layout class="org.apache.log4j.PatternLayout">
       <param name="ConversionPattern"  value="[%d{dd HH:mm:ss,SSS} %-5p] [%t] %c{2} - %m%n" />
   </layout>
</appender>

<!-- 打印到文件中 -->
<appender name="fileAppender" class="org.apache.log4j.DailyRollingFileAppender">
    <param name="File" value="${logfileName}.log" />
    <param name="DatePattern" value="'.'yyyy-MM-dd'.log'" />
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern"
               value="[%d{MMdd HH:mm:ss SSS} %-5p] [%t] %c{3} - %m%n" />
    </layout>
</appender>

<!-- logger -->
<logger name="com.test" additivity="false">
   <level value="INFO" />
   <appender-ref ref="fileAppender" />
</logger>

<!-- root -->
<root>
   <priority value ="INFO"/>
   <appender-ref ref="myConsole"/>
</root>

xml配置文件中,<appender>定义日志什么样的格式输出控制台或者文件中。<logger>决定项目中的每个class绑定哪个appender。<root>是根logger,会绑定多个appender。

loggeradditivity默认true表示此logger要打印日志也要传给root一份,让rootappender进行打印

3. 解决方案
方案

修改additivity为true,或者直接去掉,因为默认值就是true

方案

com.testlogger里面consoleappender添加进去。

<!-- logger -->
<logger name="com.test" additivity="false">
   <level value="INFO" />
   <appender-ref ref="fileAppender" />
   <appender-ref ref="myConsole" />
</logger>

这样,就解决了在控制台打印日志问题了。


95后小程序员,写的都是日常工作中的亲身实践,置身于初学者的角度从0写到1,详细且认真。文章会在公众号 [入门到放弃之路] 首发,期待你的关注

感谢每一次遇见

原文地址:https://blog.csdn.net/CatchLight/article/details/129236667

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_30326.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注