2016-11-14 12 views
2

以下、私はグローバルに適用されるログバック構成を持っています。異なるクラスの異なるログレベル

1つのクラスを除いて、ログレベルERRORをグローバルに作成したいとします。 1つの特定のクラスについては、ログレベルINFOにしたいと思います。どうやってやるの?

<configuration scan="truef" scanPeriod="30 seconds"> 

    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> 
     <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder"> 
      <layout class="com.foo.web.online.util.log.LogMaskingPatternLayout"> 

       <pattern>[START] Date: %d{yyyy-MM-dd} | Time: %d{HH:mm:ss.SSS} | Level: %-5level | Logger: %logger{5} | Marker: %marker | CIP: %X{clientIp} | UserAgent: %X{userAgent} | Website: %X{website} | SID: %X{sessionId} | RID: %X{requestId} | CID: %X{conversationId} | TID: %X{transactionId} | App: %X{app} | SubApp: %X{subApp} | Msg: %msg [END] %n</pattern> 
       </layout>  
      </encoder> 
    </appender> 

    <appender name="SIFT_INFO" class="ch.qos.logback.classic.sift.SiftingAppender"> 
     <discriminator class="ch.qos.logback.classic.sift.JNDIBasedContextDiscriminator"> 
      <defaultValue>unknown</defaultValue> 
     </discriminator> 
     <sift> 
      <appender name="FILE-${contextName}" class="ch.qos.logback.core.rolling.RollingFileAppender"> 
       <file>/opt/local/logs/online/${contextName}.log</file> 
       <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> 
        <fileNamePattern>/opt/local/logs/online/${contextName}-%d{yyyy-MM-dd}.log</fileNamePattern> 
        <maxHistory>7</maxHistory> 
       </rollingPolicy> 
       <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder"> 
        <layout class="com.foo.web.online.util.log.LogMaskingPatternLayout"> 
         <pattern>[START] Date: %d{yyyy-MM-dd} | Time: %d{HH:mm:ss.SSS} | Level: %-5level | Logger: %logger{5} | Marker: %marker | CIP: %X{clientIp} | UserAgent: %X{userAgent} | Website: %X{website} | SID: %X{sessionId} | RID: %X{requestId} | App: %X{app} | SubApp: %X{subApp} | Page: %X{page} | Device: %X{device} | Browser: %X{browser} | Lang: %X{language} | IPCountry: %X{geoIpCountry} | IPCity: %X{geoIpCity} | ErrCode: %X{errorCode} | Msg: %msg [END] %n</pattern> 
       </layout> 
        </encoder> 
      </appender> 
     </sift> 
    </appender> 


    <logger name="com.foo" level="INFO"> 
     <appender-ref ref="SIFT_INFO" /> 
     <!-- <appender-ref ref="STDOUT" /> --> 
    </logger> 

    <logger name="org.hibernate.type" level="INFO" /> 
    <logger name="org.hibernate" level="INFO" /> 


</configuration> 

答えて

2

あなたは、このようなのようなルートロガーを使用することができます。

<root> 
    <level value="ERROR"/> 
    <appender-ref ref="STDOUT"/> 
    <appender-ref ref="SIFT_INFO"/> 
</root> 
<logger name="org.mycompany.MyClass"> 
    <level value="INFO"/> 
</logger> 
+0

をどこにorg.foo.MyClassロガーへの参照を持っているのですか? – DarthVader

+0

INFOレベルを1クラスのみにしたいと言っていますが、これはクラスのFQNを入れる場所です(例を使用しました)。 – shayy

+0

これはいくらか働いている。ただし、同じログを2回印刷します。 – DarthVader

関連する問題