logback-spring.xml 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. <configuration>
  2. <!-- 引用 Spring Boot 的 logback 基础配置 -->
  3. <include resource="org/springframework/boot/logging/logback/defaults.xml" />
  4. <!-- 变量 yudao.info.base-package,基础业务包 -->
  5. <springProperty scope="context" name="yudao.info.base-package" source="yudao.info.base-package"/>
  6. <!-- 格式化输出:%d 表示日期,%X{tid} SkWalking 链路追踪编号,%thread 表示线程名,%-5level:级别从左显示 5 个字符宽度,%msg:日志消息,%n是换行符 -->
  7. <!-- <property name="PATTERN_DEFAULT" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%X{tid}] [%thread] %-5level %logger{36} -%msg%n"/>-->
  8. <property name="PATTERN_DEFAULT" value="%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss.SSS}} ${LOG_LEVEL_PATTERN:-%5p} ${PID:- } --- [%thread] [%X{tid}] %-40.40logger{39} : %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}"/>
  9. <!-- 控制台 Appender -->
  10. <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">     
  11. <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
  12. <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">
  13. <pattern>${PATTERN_DEFAULT}</pattern>
  14. </layout>
  15. </encoder>
  16. </appender>
  17. <!-- 文件 Appender -->
  18. <!-- 参考 Spring Boot 的 file-appender.xml 编写 -->
  19. <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
  20. <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
  21. <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">
  22. <pattern>${PATTERN_DEFAULT}</pattern>
  23. </layout>
  24. </encoder>
  25. <!-- 日志文件名 -->
  26. <file>${LOG_FILE}</file>
  27. <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
  28. <!-- 滚动后的日志文件名 -->
  29. <fileNamePattern>${LOGBACK_ROLLINGPOLICY_FILE_NAME_PATTERN:-${LOG_FILE}.%d{yyyy-MM-dd}.%i.gz}</fileNamePattern>
  30. <!-- 启动服务时,是否清理历史日志,一般不建议清理 -->
  31. <cleanHistoryOnStart>${LOGBACK_ROLLINGPOLICY_CLEAN_HISTORY_ON_START:-false}</cleanHistoryOnStart>
  32. <!-- 日志文件,到达多少容量,进行滚动 -->
  33. <maxFileSize>${LOGBACK_ROLLINGPOLICY_MAX_FILE_SIZE:-10MB}</maxFileSize>
  34. <!-- 日志文件的总大小,0 表示不限制 -->
  35. <totalSizeCap>${LOGBACK_ROLLINGPOLICY_TOTAL_SIZE_CAP:-0}</totalSizeCap>
  36. <!-- 日志文件的保留天数 -->
  37. <maxHistory>${LOGBACK_ROLLINGPOLICY_MAX_HISTORY:-30}</maxHistory>
  38. </rollingPolicy>
  39. </appender>
  40. <!-- 异步写入日志,提升性能 -->
  41. <appender name="ASYNC" class="ch.qos.logback.classic.AsyncAppender">
  42. <!-- 不丢失日志。默认的,如果队列的 80% 已满,则会丢弃 TRACT、DEBUG、INFO 级别的日志 -->
  43. <discardingThreshold>0</discardingThreshold>
  44. <!-- 更改默认的队列的深度,该值会影响性能。默认值为 256 -->
  45. <queueSize>256</queueSize>
  46. <appender-ref ref="FILE"/>
  47. </appender>
  48. <!-- SkyWalking GRPC 日志收集,实现日志中心。注意:SkyWalking 8.4.0 版本开始支持 -->
  49. <appender name="GRPC" class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.log.GRPCLogClientAppender">
  50. <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
  51. <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.mdc.TraceIdMDCPatternLogbackLayout">
  52. <pattern>${PATTERN_DEFAULT}</pattern>
  53. </layout>
  54. </encoder>
  55. </appender>
  56. <!-- 本地环境 -->
  57. <springProfile name="local">
  58. <logger name="${yudao.info.base-package}" level="INFO" additivity="false">
  59. <appender-ref ref="STDOUT"/>
  60. <appender-ref ref="GRPC"/>
  61. <appender-ref ref="ASYNC"/>
  62. <!-- 本地环境下,不打印日志文件 -->
  63. </logger>
  64. </springProfile>
  65. <!-- 其它环境 -->
  66. <springProfile name="default">
  67. <logger name="${yudao.info.base-package}" level="INFO" additivity="false">
  68. <appender-ref ref="STDOUT"/>
  69. <appender-ref ref="ASYNC"/>
  70. <appender-ref ref="GRPC"/>
  71. </logger>
  72. </springProfile>
  73. </configuration>