2
아래에는 전역 적으로 적용되는 로그백 구성이 있습니다.다른 클래스의 다른 로그 수준
하나의 클래스를 제외하고 전체적으로 로깅 수준을 ERROR로 만들고 싶습니다. 특정 클래스의 경우 로깅 수준을 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>
을 어디 org.foo.MyClass 로거에 대한 참조를해야합니까? – DarthVader
당신은 하나의 클래스에서만 INFO 레벨을 원한다고 말했 읍니다. 여기는 클래스의 FQN을 넣는 곳입니다 (방금 예제를 사용했습니다). – shayy
확인. 이것은 다소 효과적입니다. 단, 동일한 로그를 두 번 인쇄합니다. – DarthVader