| | |
| | | <?xml version="1.0" encoding="UTF-8"?> |
| | | <configuration scan="true" scanPeriod="60 seconds"> |
| | | |
| | | <!--包含etl tool 的logback文件--> |
| | | <include resource="logback/logback.xml"/> |
| | | <!-- 日志文件输出目录 --> |
| | | <property name="LOG_DIR" value="D:/mdmnew/devlogs" /> |
| | | <property name="APP_NAME" value="mdm-appdev" /> |
| | | |
| | | <!-- 自定义参数监听 --> |
| | | <contextListener class="org.springblade.core.log.listener.LoggerStartupListener"/> |
| | | <springProperty scope="context" name="springAppName" source="spring.application.name"/> |
| | | |
| | | <!-- 彩色日志依赖的渲染类 --> |
| | | <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> |
| | | <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"> |
| | | <encoder> |
| | | <!-- <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>--> |
| | | <pattern>%d{HH:mm:ss.SSS} [%thread] %highlight(%-5level) %cyan(%logger{15}) - %msg%n</pattern> |
| | | </encoder> |
| | | </appender> |
| | | |
| | | <!-- 主日志文件 --> |
| | | <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> |
| | | <file>${LOG_FILE}</file> |
| | | <file>${LOG_DIR}/${APP_NAME}.log</file> |
| | | <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> |
| | | <fileNamePattern>${LOG_DIR}/${APP_NAME}.%d{yyyy-MM-dd}.log</fileNamePattern> |
| | | <maxHistory>30</maxHistory> |
| | | </rollingPolicy> |
| | | <encoder> |
| | | <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern> |
| | | </encoder> |
| | | <!-- 滚动策略 --> |
| | | <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"> |
| | | <!-- 按日期和大小滚动 --> |
| | | <fileNamePattern>${LOG_PATH}/mdm-%d{yyyy-MM-dd}.%i.log</fileNamePattern> |
| | | <!-- 单个文件最大大小 --> |
| | | <maxFileSize>100MB</maxFileSize> |
| | | <!-- 保留最多30天的日志 --> |
| | | <maxHistory>30</maxHistory> |
| | | <!-- 所有日志文件总大小限制 --> |
| | | <totalSizeCap>2GB</totalSizeCap> |
| | | </rollingPolicy> |
| | | </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}", |
| | | "requestId": "%X{requestId}", |
| | | "accountId": "%X{accountId}", |
| | | "tenantId": "%X{tenantId}", |
| | | "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> |
| | | |
| | | <!-- 日志输出级别 --> |
| | | <!-- 专门记录org.springblade.mdm包的日志 --> |
| | | <appender name="MDM_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> |
| | | <file>${LOG_DIR}/mdmdev-core.log</file> |
| | | <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> |
| | | <fileNamePattern>${LOG_DIR}/mdm-coredev.%d{yyyy-MM-dd}.log</fileNamePattern> |
| | | <maxHistory>30</maxHistory> |
| | | </rollingPolicy> |
| | | <encoder> |
| | | <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern> |
| | | </encoder> |
| | | </appender> |
| | | |
| | | <!-- 根日志级别 --> |
| | | <root level="INFO"> |
| | | <appender-ref ref="STDOUT"/> |
| | | <appender-ref ref="FILE"/> |
| | | |
| | | <appender-ref ref="${STDOUT_APPENDER}"/> |
| | | <appender-ref ref="CONSOLE" /> |
| | | <appender-ref ref="FILE" /> |
| | | </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="INFO"/> |
| | | <logger name="java.sql.Connection" level="INFO"/> |
| | | <logger name="java.sql.Statement" level="INFO"/> |
| | | <logger name="java.sql.PreparedStatement" level="INFO"/> |
| | | |
| | | <!-- 减少部分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.mdm" level="INFO"/> |
| | | <Logger name="org.springblade.core.tenant" level="INFO"/> |
| | | <Logger name="org.springblade.core.version" level="INFO"/> |
| | | |
| | | <!-- 减少nacos日志 --> |
| | | <logger name="com.alibaba.nacos" level="ERROR"/> |
| | | |
| | | |
| | | |
| | | <logger name="RocketmqClient" additivity="false"> |
| | | <level value="ERROR" /> |
| | | <appender-ref ref="STDOUT"/> |
| | | <!-- 专门配置org.springblade.mdm包的日志 --> |
| | | <logger name="org.springblade.mdm" level="DEBUG" additivity="false"> |
| | | <appender-ref ref="MDM_FILE" /> |
| | | <appender-ref ref="CONSOLE" /> |
| | | </logger> |
| | | </configuration> |