2012-09-13 2 views
0

특정 클래스에 로거를 별도의 파일에 기록하도록 구성하려고합니다. 하지만 패키지 로거와 동일한 레벨을 가지고 있으며 메시지는 두 번 쓰여집니다.패키지 및 클래스 로깅 분할

MyClass에에서
<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> 

나는이 방법으로 로거를 얻을 : 계층 구조에서

Logger.getLogger(this); 
+1

유사한 문제에 대한 구성 플래그가 있었지만 additivity라는 이름이 붙어 있었지만 이전에 사용했습니다. – 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의 메시지를 기록하지 않습니다 여기에

내 구성입니다