2012-09-13 39 views
0

我想配置某些類的記錄器來寫入單獨的文件。 但我有相同的程序包記錄器和消息被寫入兩次。拆分包和類日誌記錄

這裏是我的配置:

<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.getLogger(this); 
+1

有一個類似問題的配置標誌,它被命名爲疊加,但我很久以前使用過。 – BigMike

+0

剛剛閱讀關於可加性http://logging.apache.org/log4j/1.2/manual.html –

回答

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

和 「上」 伐木工人在層次結構不會從package.MyClass日誌信息