0

特定のクラスのロガーを別のファイルに書き込むように設定したいと思います。しかし、パッケージ ロガーのレベルが同じで、メッセージが 2 回書き込まれます。

これが私の構成です:

<appender name="FILE_TRACE" class="org.apache.log4j.RollingFileAppender">
    <param name="File" value="c:/logs/trace.log"/>
    <param name="MaxFileSize" value="100MB"/>
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern" value="%X{user} - %X{docbase} - %X{sysObjectId} - %d{ABSOLUTE} [%t] %m%n"/>
    </layout>
</appender>

<appender name="QUERY_TRACE" class="org.apache.log4j.RollingFileAppender">
    <param name="File" value="c:/logs/query.log"/>
    <param name="MaxFileSize" value="100MB"/>
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern" value="%X{user} - %X{docbase} - %X{sysObjectId} - %d{ABSOLUTE} [%t] %m%n"/>
    </layout>
</appender>

<appender name="stdout" class="org.apache.log4j.ConsoleAppender">
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern" value="[%d{ISO8601}|%-5p|%-22t|%C|%M|%-4L] %m%n"/>
    </layout>
</appender>

   <logger name="package">
        <level value="DEBUG"/>
        <appender-ref ref="FILE_TRACE"/>
    </logger>

    <logger name="package.MyClass">
        <level value="DEBUG" />
        <appender-ref ref="QUERY_TRACE"/>
    </logger>

    <root>
        <level value="INFO"/>
        <appender-ref ref="stdout"/>
    </root>

MyClass では、次の方法で Logger を取得します。

Logger.getLogger(this);
4

1 に答える 1

0
<logger name="package.MyClass" additivity="false">
        <level value="DEBUG" />
        <appender-ref ref="QUERY_TRACE"/>
</logger>

また、階層の「上位」ロガーはメッセージをログに記録しませんpackage.MyClass

于 2012-09-17T07:19:53.777 に答える