java - 不同类的不同日志级别

标签 java log4j logback slf4j

下面,我有一个全局应用的 logback 配置。

除了一个类,我想全局设置日志记录级别 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>

最佳答案

您可以像这样使用根记录器:

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

关于java - 不同类的不同日志级别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40586985/

相关文章:

multithreading - 在Logback中记录并行线程

java - 如何在返回多种 XML 类型的 URL 上使用 Spring RestTemplate 和 JAXB 编码

java - 我可以在 cucumber 测试中使用 Spring 自动连接 Controller 吗?

java - 通过 Logback 的 Dropwizard 自定义日志文件

java - 如何从 Java 代码禁用 log4j 日志记录

java - 在重新启动 WebLogic 之前不会生成日志文件

multithreading - Log4J - 类似 SiftingAppender 的功能

java - 并发线程访问单例

java - 从android应用程序中的大图片中提取和使用图像缩略图

java - log4j:如何仅输出我感兴趣的消息