0

在我们的项目中,目前我们有一个主要的portal-log4j.xml,在我们的项目中,我们需要使用portal-log4j-ext.xml覆盖它 。在portal-log4j.xml 中,我们默认将所有日志记录到控制台.

    <root>
    <priority value="INFO" />
    <appender-ref ref="CONSOLE" />
    <appender-ref ref="FILE" />
</root>

在覆盖的 portal-log4j-ext.xml 文件中,我们有以下代码:

<appender name="FILE" class="org.apache.log4j.RollingFileAppender">
    <param name="maxFileSize" value="10000kb" />
    <param name="maxBackupIndex" value="20" />
    <param name="file" value="D:/myLogFile.log" />
    <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="&#37;d{ISO8601} &#37;-5p [&#37;C{1}] &#37;x: &#37;m&#37;n"/>
    </layout>
</appender>     

<logger name="com.company.layoutimporter">
    <level value="DEBUG" />
    <appender-ref ref="FILE" />
</logger>

如您所见,我可以写入文件,但它也可以在控制台中记录。我们如何覆盖此默认行为,以便我可以将特定于包的消息仅记录到特定的日志文件(而不是控制台)。

提前致谢 !

4

1 回答 1

0

我自己找到了一个解决方案.. 只需将additivity="false"添加到记录器标签。

这基本上会通过父标签再次跳过日志记录。

更多信息:可加性 - 什么以及为什么?

于 2012-03-29T12:35:24.433 回答