You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
155 lines
7.0 KiB
155 lines
7.0 KiB
<?xml version="1.0" encoding="UTF-8"?> |
|
<configuration scan="true" scanPeriod="60 seconds"> |
|
<!-- 自定义参数监听 --> |
|
<contextListener class="org.springblade.core.log.listener.LoggerStartupListener"/> |
|
|
|
<!-- 彩色日志依赖的渲染类 --> |
|
<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:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"/> |
|
<!-- 控制台输出 --> |
|
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> |
|
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> |
|
<pattern>${CONSOLE_LOG_PATTERN}</pattern> |
|
<charset>utf8</charset> |
|
</encoder> |
|
</appender> |
|
|
|
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 --> |
|
<property name="log.pattern" |
|
value="[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%t] [%X{traceId}] %-5level %logger{50} - %msg%n"/> |
|
|
|
<!-- 生成日志文件 --> |
|
<appender name="INFO" class="ch.qos.logback.core.rolling.RollingFileAppender"> |
|
<file>log/info.log</file> |
|
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> |
|
<!-- 日志文件输出的文件名 --> |
|
<FileNamePattern>log/%d{yyyy-MM-dd, aux}/info_%d{yyyy-MM-dd}.log</FileNamePattern> |
|
<!--日志文件保留天数 --> |
|
<MaxHistory>15</MaxHistory> |
|
<cleanHistoryOnStart>true</cleanHistoryOnStart> |
|
</rollingPolicy> |
|
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> |
|
<pattern>${log.pattern}</pattern> |
|
</encoder> |
|
<!-- 打印日志级别 --> |
|
<filter class="ch.qos.logback.classic.filter.LevelFilter"> |
|
<level>INFO</level> |
|
<onMatch>ACCEPT</onMatch> |
|
<onMismatch>DENY</onMismatch> |
|
</filter> |
|
</appender> |
|
|
|
<!-- 生成日志文件 --> |
|
<appender name="ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender"> |
|
<file>log/error.log</file> |
|
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> |
|
<!-- 日志文件输出的文件名 --> |
|
<FileNamePattern>log/%d{yyyy-MM-dd, aux}/error_%d{yyyy-MM-dd}.log</FileNamePattern> |
|
<!--日志文件保留天数 --> |
|
<MaxHistory>30</MaxHistory> |
|
<cleanHistoryOnStart>true</cleanHistoryOnStart> |
|
</rollingPolicy> |
|
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> |
|
<pattern>${log.pattern}</pattern> |
|
</encoder> |
|
<!-- 打印日志级别 --> |
|
<filter class="ch.qos.logback.classic.filter.LevelFilter"> |
|
<level>ERROR</level> |
|
<onMatch>ACCEPT</onMatch> |
|
<onMismatch>DENY</onMismatch> |
|
</filter> |
|
</appender> |
|
|
|
<if condition='property("ELK_MODE").toUpperCase().contains("TRUE")'> |
|
<then> |
|
<!-- 推送日志至elk --> |
|
<appender name="STDOUT_LOGSTASH" class="net.logstash.logback.appender.LogstashTcpSocketAppender"> |
|
<destination>${DESTINATION}</destination> |
|
<!-- 日志输出编码 --> |
|
<encoder charset="UTF-8" class="net.logstash.logback.encoder.LoggingEventCompositeJsonEncoder"> |
|
<providers> |
|
<timestamp> |
|
<timeZone>UTC</timeZone> |
|
</timestamp> |
|
<pattern> |
|
<pattern> |
|
{ |
|
"traceId": "%X{traceId}", |
|
"logLevel": "%level", |
|
"serviceName": "${springAppName:-SpringApp}", |
|
"pid": "${PID:-}", |
|
"thread": "%thread", |
|
"class": "%logger{40}", |
|
"line":"%L", |
|
"message": "%message" |
|
} |
|
</pattern> |
|
</pattern> |
|
<mdc/> |
|
<stackTrace/> |
|
</providers> |
|
</encoder> |
|
</appender> |
|
</then> |
|
</if> |
|
|
|
<!-- 日志输出级别 --> |
|
<root level="INFO"> |
|
<appender-ref ref="STDOUT"/> |
|
<appender-ref ref="INFO"/> |
|
<appender-ref ref="ERROR"/> |
|
</root> |
|
|
|
<logger name="net.sf.ehcache" level="INFO"/> |
|
<logger name="druid.sql" level="INFO"/> |
|
|
|
|
|
<!-- MyBatis log configure --> |
|
<logger name="com.apache.ibatis" level="INFO"/> |
|
<logger name="org.mybatis.spring" level="DEBUG"/> |
|
<logger name="java.sql.Connection" level="DEBUG"/> |
|
<logger name="java.sql.Statement" level="DEBUG"/> |
|
<logger name="java.sql.PreparedStatement" level="DEBUG"/> |
|
|
|
<!-- 减少部分debug日志 --> |
|
<logger name="druid.sql" level="INFO"/> |
|
<logger name="org.apache.shiro" level="INFO"/> |
|
<logger name="org.mybatis.spring" level="INFO"/> |
|
<logger name="org.springframework" level="INFO"/> |
|
<logger name="org.springframework.context" level="WARN"/> |
|
<logger name="org.springframework.beans" level="WARN"/> |
|
<logger name="com.baomidou.mybatisplus" level="INFO"/> |
|
<logger name="org.apache.ibatis.io" level="INFO"/> |
|
<logger name="org.apache.velocity" level="INFO"/> |
|
<logger name="org.eclipse.jetty" level="INFO"/> |
|
<logger name="io.undertow" level="INFO"/> |
|
<logger name="org.xnio.nio" level="INFO"/> |
|
<logger name="org.thymeleaf" level="INFO"/> |
|
<logger name="springfox.documentation" level="INFO"/> |
|
<logger name="org.hibernate.validator" level="INFO"/> |
|
<logger name="com.netflix.loadbalancer" level="INFO"/> |
|
<logger name="com.netflix.hystrix" level="INFO"/> |
|
<logger name="com.netflix.zuul" level="INFO"/> |
|
<logger name="de.codecentric" level="INFO"/> |
|
<!-- cache INFO --> |
|
<logger name="net.sf.ehcache" level="INFO"/> |
|
<logger name="org.springframework.cache" level="INFO"/> |
|
<!-- cloud --> |
|
<logger name="org.apache.http" level="INFO"/> |
|
<logger name="com.netflix.discovery" level="INFO"/> |
|
<logger name="com.netflix.eureka" level="INFO"/> |
|
<!-- 业务日志 --> |
|
<Logger name="org.springblade" level="DEBUG"/> |
|
<Logger name="org.springblade.core.version" level="INFO"/> |
|
|
|
<!-- 减少nacos日志 --> |
|
<logger name="com.alibaba.nacos" level="ERROR"/> |
|
|
|
|
|
</configuration>
|
|
|