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();