124 lines
6.6 KiB
XML
124 lines
6.6 KiB
XML
<?xml version="1.0" encoding="UTF-8"?>
|
||
<configuration>
|
||
<contextName>logback</contextName>
|
||
|
||
<!-- 彩色日志依赖的渲染类 -->
|
||
<conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter"/>
|
||
<conversionRule conversionWord="wex"
|
||
converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter"/>
|
||
<conversionRule conversionWord="wEx"
|
||
converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter"/>
|
||
|
||
<!-- 彩色日志格式 -->
|
||
<property name="CONSOLE_LOG_PATTERN" value="${CONSOLE_LOG_PATTERN:-%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(${LOG_LEVEL_PATTERN:-%1p}) %clr(${PID:- }){magenta} %clr(--){faint} %clr([%1.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"/>
|
||
|
||
<!-- 日志路径和编码配置 -->
|
||
<springProperty scope="context" name="logPath" source="logging.file.path" defaultValue="logdir"/>
|
||
<springProperty scope="context" name="encodings" source="logging.encodings" defaultValue="UTF-8"/>
|
||
<property name="LOG_HOME" value="${logPath}"/>
|
||
<property name="MAX_HISTORY" value="50"/>
|
||
<property name="MAX_FILE_SIZE" value="50MB"/>
|
||
|
||
<!-- 控制台输出(已正确配置编码) -->
|
||
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
|
||
<encoder class="com.yomahub.tlog.core.enhance.logback.AspectLogbackEncoder">
|
||
<Pattern>${CONSOLE_LOG_PATTERN}</Pattern>
|
||
<charset>${encodings}</charset> <!-- 控制台编码:UTF-8 -->
|
||
</encoder>
|
||
</appender>
|
||
|
||
<!-- INFO级别日志输出到文件(新增charset配置) -->
|
||
<appender name="INFO_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
||
<filter class="ch.qos.logback.classic.filter.LevelFilter">
|
||
<level>INFO</level>
|
||
<onMatch>ACCEPT</onMatch>
|
||
<onMismatch>DENY</onMismatch>
|
||
</filter>
|
||
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
|
||
<maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
|
||
<maxHistory>${MAX_HISTORY}</maxHistory>
|
||
<fileNamePattern>${LOG_PATH}/%d{yyyy-MM-dd}/info/info_%d{yyyyMMdd}.%i.log</fileNamePattern>
|
||
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
||
<maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
|
||
</timeBasedFileNamingAndTriggeringPolicy>
|
||
</rollingPolicy>
|
||
<encoder class="com.yomahub.tlog.core.enhance.logback.AspectLogbackEncoder">
|
||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
|
||
<charset>${encodings}</charset> <!-- 文件编码:UTF-8 -->
|
||
</encoder>
|
||
</appender>
|
||
|
||
<!-- WARN级别日志(新增charset配置) -->
|
||
<appender name="WARN_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
||
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
|
||
<maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
|
||
<maxHistory>${MAX_HISTORY}</maxHistory>
|
||
<fileNamePattern>${LOG_PATH}/%d{yyyy-MM-dd}/warn/warn_%d{yyyyMMdd}.%i.log</fileNamePattern>
|
||
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
||
<maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
|
||
</timeBasedFileNamingAndTriggeringPolicy>
|
||
</rollingPolicy>
|
||
<filter class="ch.qos.logback.classic.filter.LevelFilter">
|
||
<level>WARN</level>
|
||
<onMatch>ACCEPT</onMatch>
|
||
<onMismatch>DENY</onMismatch>
|
||
</filter>
|
||
<encoder class="com.yomahub.tlog.core.enhance.logback.AspectLogbackEncoder">
|
||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
|
||
<charset>${encodings}</charset> <!-- 文件编码:UTF-8 -->
|
||
</encoder>
|
||
</appender>
|
||
|
||
<!-- ERROR级别日志(新增charset配置) -->
|
||
<appender name="ERROR_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
||
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
|
||
<maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
|
||
<maxHistory>${MAX_HISTORY}</maxHistory>
|
||
<fileNamePattern>${LOG_PATH}/%d{yyyy-MM-dd}/error/error_%d{yyyyMMdd}.%i.log</fileNamePattern>
|
||
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
||
<maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
|
||
</timeBasedFileNamingAndTriggeringPolicy>
|
||
</rollingPolicy>
|
||
<filter class="ch.qos.logback.classic.filter.LevelFilter">
|
||
<level>ERROR</level>
|
||
<onMatch>ACCEPT</onMatch>
|
||
<onMismatch>DENY</onMismatch>
|
||
</filter>
|
||
<encoder class="com.yomahub.tlog.core.enhance.logback.AspectLogbackEncoder">
|
||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
|
||
<charset>${encodings}</charset> <!-- 文件编码:UTF-8 -->
|
||
</encoder>
|
||
</appender>
|
||
|
||
<!-- ALL级别日志(新增charset配置) -->
|
||
<appender name="ALL_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
||
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
|
||
<maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
|
||
<maxHistory>${MAX_HISTORY}</maxHistory>
|
||
<fileNamePattern>${LOG_PATH}/%d{yyyy-MM-dd}/all/all_%d{yyyyMMdd}.%i.log</fileNamePattern>
|
||
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
||
<maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
|
||
</timeBasedFileNamingAndTriggeringPolicy>
|
||
</rollingPolicy>
|
||
<encoder class="com.yomahub.tlog.core.enhance.logback.AspectLogbackEncoder">
|
||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
|
||
<charset>${encodings}</charset> <!-- 文件编码:UTF-8 -->
|
||
</encoder>
|
||
</appender>
|
||
|
||
<!-- 根日志配置 -->
|
||
<root level="INFO">
|
||
<appender-ref ref="CONSOLE"/>
|
||
<appender-ref ref="INFO_FILE"/>
|
||
<appender-ref ref="WARN_FILE"/>
|
||
<appender-ref ref="ERROR_FILE"/>
|
||
<appender-ref ref="ALL_FILE"/>
|
||
</root>
|
||
<root level="ERROR">
|
||
<appender-ref ref="INFO_FILE"/>
|
||
<appender-ref ref="WARN_FILE"/>
|
||
<appender-ref ref="ERROR_FILE"/>
|
||
<appender-ref ref="ALL_FILE"/>
|
||
</root>
|
||
</configuration>
|