关于log4j的一个坑

栏目: Java · 发布时间: 5年前

内容简介:在生产环境的日志配置中新加了一个日志文件输出配置,如下注释处:这个新增的配置会在原有的日志文件 main.log 外,新增一个全新的日志文件 analysis.log 记录一些信息。结果上线后,不仅日志输出到了 analysis.log,同时也输出到了 main.log 中了一份,冗余了。Google 了一下,原来是原来,在如下的两个

在生产环境的日志配置中新加了一个日志文件输出配置,如下注释处:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<log4j:configuration>
    <appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="[%d{MM-dd HH:mm:ss,SSS\} %-5p] [%t] %c{2\}:%L - %m%n"/>
        </layout>
        <filter class="org.apache.log4j.varia.LevelRangeFilter">
            <param name="levelMin" value="error"/>
            <param name="levelMax" value="off"/>
            <param name="AcceptOnMatch" value="true"/>
        </filter>
    </appender>

    <appender name="DAILY_ROLLING_FILE" class="org.apache.log4j.DailyRollingFileAppender">
        <param name="File" value="../log/main.log"/>
        <param name="DatePattern" value="'.'yyyy-MM-dd'.log'"/>
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="[%d{MM-dd HH:mm:ss SSS\} %-5p] [%t] %c{3\}:%L - %m%n"/>
        </layout>
        <filter class="org.apache.log4j.varia.LevelMatchFilter">
            <param name="LevelToMatch" value="ERROR"/>
            <param name="AcceptOnMatch" value="true"/>
        </filter>
    </appender>

    <!-- 新增配置开始 -->
    <appender name="ANALYSIS_DAILY_ROLLING_FILE" class="org.apache.log4j.DailyRollingFileAppender">
        <param name="File" value="../log/analysis.log"/>
        <param name="DatePattern" value="'.'yyyy-MM-dd'.log'"/>
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%m%n"/>
        </layout>
        <filter class="org.apache.log4j.varia.LevelMatchFilter">
            <param name="LevelToMatch" value="INFO"/>
            <param name="AcceptOnMatch" value="true"/>
        </filter>
    </appender>

    <appender name="ASYNC_ANALYSIS_DAILY_ROLLING_FILE" class="org.apache.log4j.AsyncAppender">
        <appender-ref ref="ANALYSIS_DAILY_ROLLING_FILE"/>
    </appender>

    <logger name="LOGGER_ANALYSIS">
        <level value="INFO"/>
        <appender-ref ref="ASYNC_ANALYSIS_DAILY_ROLLING_FILE"/>
    </logger>
    <!-- 新增配置结束 -->

    <root>
        <level value="ERROR"/>
        <appender-ref ref="DAILY_ROLLING_FILE"/>
    </root>
</log4j:configuration>

这个新增的配置会在原有的日志文件 main.log 外,新增一个全新的日志文件 analysis.log 记录一些信息。结果上线后,不仅日志输出到了 analysis.log,同时也输出到了 main.log 中了一份,冗余了。Google 了一下,原来是 rootadditivity 的问题。

原来,在如下的两个 logger 中,存在着继承关系, LOGGER_ANALYSIS 是继承了 root

<logger name="LOGGER_ANALYSIS">
    <level value="INFO"/>
    <appender-ref ref="ASYNC_ANALYSIS_DAILY_ROLLING_FILE"/>
</logger>

<root>
    <level value="ERROR"/>
    <appender-ref ref="DAILY_ROLLING_FILE"/>
</root>

继承,就意味着 LOGGER_ANALYSIS 是继承了 rootappender-ref 的,因此, LOGGER_ANALYSIS 不知输出到了自己的 appender 设置的文件 analysis.log 里,也会输出到 DAILY_ROLLING_FILE 对应的 main.log 里,也就是冗余了。

那么,怎么解决呢?很简单,让儿子不继承爸爸就好了,不做富二代,白手起家,自己打天下。

<logger name="LOGGER_ANALYSIS" additivity="false">
    <level value="INFO"/>
    <appender-ref ref="ASYNC_ANALYSIS_DAILY_ROLLING_FILE"/>
</logger>

注意上边的 additivity="false" 就这个设置,就声明和 root 脱离父子关系了,独立了。问题解决。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

蚂蚁金服

蚂蚁金服

由曦 / 中信出版集团股份有限公司 / 2017-4-7 / CNY 59.00

在中国,支付宝(其母公司为蚂蚁金服)是一个家喻户晓的品牌。我们在用手机扫码支付,或者用余额宝理财的时候,一定会和支付宝发生关系。但是很多人不知道,支付宝的母公司叫作“蚂蚁金服”。蚂蚁金服不仅有支付宝,还有余额宝、网商银行、芝麻信用等一系列产品和服务。成立于2004年、起始于支付宝的蚂蚁金服集团,如今已经是全球估值最高的科技金融企业。然而,在成立之初,它只是淘宝网的结算部门,员工只有区区几人,记账用......一起来看看 《蚂蚁金服》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

SHA 加密
SHA 加密

SHA 加密工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具