FlowPacs/yudao-admin-server/src/main/resources/logback-spring.xml

77 lines
4.2 KiB
XML
Raw Normal View History

2021-04-26 09:46:49 +08:00
<configuration>
2021-04-26 20:47:42 +08:00
<!-- 引用 Spring Boot 的 logback 基础配置 -->
<include resource="org/springframework/boot/logging/logback/defaults.xml" />
<!-- 变量 yudao.info.base-package基础业务包 -->
2021-04-26 09:46:49 +08:00
<springProperty scope="context" name="yudao.info.base-package" source="yudao.info.base-package"/>
2021-04-26 20:47:42 +08:00
<!-- 格式化输出:%d 表示日期,%X{tid} SkWalking 链路追踪编号,%thread 表示线程名,%-5level级别从左显示 5 个字符宽度,%msg日志消息%n是换行符 -->
2021-04-26 21:53:54 +08:00
<property name="PATTERN_DEFAULT" value="%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss.SSS}} ${LOG_LEVEL_PATTERN:-%5p} ${PID:- } --- [%thread] [%tid] %-40.40logger{39} : %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}"/>
2021-04-26 09:46:49 +08:00
<!-- 控制台 Appender -->
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">     
<encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
2021-04-26 01:35:05 +08:00
<layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">
2021-04-26 09:46:49 +08:00
<pattern>${PATTERN_DEFAULT}</pattern>
</layout>
</encoder>
</appender>
2021-04-26 01:35:05 +08:00
2021-04-26 09:46:49 +08:00
<!-- 文件 Appender -->
2021-04-26 20:47:42 +08:00
<!-- 参考 Spring Boot 的 file-appender.xml 编写 -->
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
<layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">
2021-04-26 09:46:49 +08:00
<pattern>${PATTERN_DEFAULT}</pattern>
</layout>
</encoder>
2021-04-26 20:47:42 +08:00
<!-- 日志文件名 -->
<file>${LOG_FILE}</file>
2021-04-26 09:46:49 +08:00
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
2021-04-26 20:47:42 +08:00
<!-- 滚动后的日志文件名 -->
<fileNamePattern>${LOGBACK_ROLLINGPOLICY_FILE_NAME_PATTERN:-${LOG_FILE}.%d{yyyy-MM-dd}.%i.gz}</fileNamePattern>
<!-- 启动服务时,是否清理历史日志,一般不建议清理 -->
<cleanHistoryOnStart>${LOGBACK_ROLLINGPOLICY_CLEAN_HISTORY_ON_START:-false}</cleanHistoryOnStart>
<!-- 日志文件,到达多少容量,进行滚动 -->
<maxFileSize>${LOGBACK_ROLLINGPOLICY_MAX_FILE_SIZE:-10MB}</maxFileSize>
<!-- 日志文件的总大小0 表示不限制 -->
<totalSizeCap>${LOGBACK_ROLLINGPOLICY_TOTAL_SIZE_CAP:-0}</totalSizeCap>
<!-- 日志文件的保留天数 -->
<maxHistory>${LOGBACK_ROLLINGPOLICY_MAX_HISTORY:-30}</maxHistory>
2021-04-26 09:46:49 +08:00
</rollingPolicy>
</appender>
2021-04-26 20:47:42 +08:00
<!-- 异步写入日志,提升性能 -->
<appender name="ASYNC" class="ch.qos.logback.classic.AsyncAppender">
2021-04-26 20:47:42 +08:00
<!-- 不丢失日志。默认的,如果队列的 80% 已满,则会丢弃 TRACT、DEBUG、INFO 级别的日志 -->
<discardingThreshold>0</discardingThreshold>
2021-04-26 20:47:42 +08:00
<!-- 更改默认的队列的深度,该值会影响性能。默认值为 256 -->
<queueSize>256</queueSize>
<appender-ref ref="FILE"/>
</appender>
2021-04-26 01:35:05 +08:00
2021-04-26 09:46:49 +08:00
<!-- SkyWalking GRPC 日志收集实现日志中心。注意SkyWalking 8.4.0 版本开始支持 -->
<appender name="GRPC" class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.log.GRPCLogClientAppender">
2021-04-26 01:35:05 +08:00
<encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
2021-04-26 21:53:54 +08:00
<layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">
2021-04-26 09:46:49 +08:00
<pattern>${PATTERN_DEFAULT}</pattern>
2021-04-26 01:35:05 +08:00
</layout>
2021-04-26 09:46:49 +08:00
</encoder>
</appender>
2021-04-26 09:46:49 +08:00
<!-- 本地环境 -->
<springProfile name="local">
<root level="INFO">
<appender-ref ref="STDOUT"/>
2021-04-26 21:53:54 +08:00
<appender-ref ref="GRPC"/> <!-- 本地环境下,如果不想接入 SkyWalking 日志服务,可以注释掉本行 -->
<appender-ref ref="ASYNC"/> <!-- 本地环境下,如果不想打印日志,可以注释掉本行 -->
</root>
</springProfile>
2021-04-26 09:46:49 +08:00
<!-- 其它环境 -->
<springProfile name="default">
<root level="INFO">
<appender-ref ref="STDOUT"/>
<appender-ref ref="ASYNC"/>
2021-04-26 09:46:49 +08:00
<appender-ref ref="GRPC"/>
</root>
</springProfile>
2021-04-26 01:35:05 +08:00
</configuration>