按照日志种类不同分别存到两个日志文件

logback按照日志种类不同分别存到两个日志文件

配置不同的<appender>不同的name属性值,及对应的<logger>:

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false" scan="true" scanPeriod="1 seconds">

    <contextName>logback</contextName>
    <property name="log.path" value="logs"/>

    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <!-- <filter class="ch.qos.logback.classic.filter.ThresholdFilter" >
             <level>WARN</level>
         </filter>-->
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{5}[%file:%line] %msg%n</pattern>
        </encoder>
    </appender>

    <appender name="datafile" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.path}/executor.data.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <fileNamePattern>${log.path}/%d{yyyy-MM-dd}.executor.data.%i.zip</fileNamePattern>
            <!--按天回滚,保存60天以内的,文件最大达到100MB会被切割。日志总保存量1G-->
            <maxFileSize>1MB</maxFileSize>
            <totalSizeCap>2MB</totalSizeCap>
            <maxHistory>100</maxHistory>
        </rollingPolicy>

        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{5}[%file:%line] %msg%n</pattern>
        </encoder>
    </appender>

    <appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.path}/executor.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${log.path}/%d{yyyy-MM-dd}.executor.%i.zip</fileNamePattern>
            <maxHistory>100</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>100MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>

        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{5}[%file:%line] %msg%n</pattern>
        </encoder>
    </appender>

    <logger name="datafile" additivity="false" level="INFO">
        <appender-ref ref="datafile"/>
    </logger>

    <logger name="file" additivity="false" level="INFO">
        <appender-ref ref="file"/>
    </logger>

    <root level="info">
<!--        <appender-ref ref="console"/>-->
        <!--<appender-ref ref="datafile"/>-->
        <appender-ref ref="file"/><!--info以上的都存到file里-->
    </root>

</configuration>

建两个不同的logger分别对用两个name:

private static Logger logger = LoggerFactory.getLogger("file");
private static Logger loggera = LoggerFactory.getLogger("datafile");

将不同的日志存到不同的日志文件里:

logger.info();
loggera.info();





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值