logback-spring.xml 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. <configuration>
  2. <!-- 参考 org/springframework/boot/logging/logback/defaults.xml 配置,优化 CONSOLE_LOG_PATTERN、FILE_LOG_PATTERN -->
  3. <!-- 格式化输出:%d 表示日期,%thread 表示线程名,%-5level:级别从左显示 5 个字符宽度,%msg:日志消息,%n是换行符 -->
  4. <!-- CONSOLE_LOG_PATTERN 相比 FILE_LOG_PATTERN 多了 highlight、cyan 等高亮 -->
  5. <property name="CONSOLE_LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %highlight(%-5level) %cyan(%logger{50}:%L) - %msg%n"/>
  6. <property name="FILE_LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50}:%L - %msg%n"/>
  7. <!-- 控制台 Appender -->
  8. <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">     
  9. <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
  10. <pattern>${CONSOLE_LOG_PATTERN}</pattern>
  11. </encoder>
  12. </appender>
  13. <!-- 文件 Appender -->
  14. <!-- 参考 Spring Boot 的 file-appender.xml 编写 -->
  15. <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
  16. <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
  17. <pattern>${FILE_LOG_PATTERN}</pattern>
  18. </encoder>
  19. <!-- 日志文件名 -->
  20. <file>${LOG_FILE}</file>
  21. <!-- 滚动策略:基于【每天 + 大小】创建日志文件 -->
  22. <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
  23. <fileNamePattern>${LOG_FILE}.%d{yyyy-MM-dd}.%i.log</fileNamePattern> <!-- 日志文件输出的文件名 -->
  24. <maxHistory>30</maxHistory> <!-- 日志文件的保留天数 -->
  25. <maxFileSize>10MB</maxFileSize> <!-- 日志文件,到达多少容量,进行滚动 -->
  26. </rollingPolicy>
  27. </appender>
  28. <!-- 异步写入日志,提升性能 -->
  29. <appender name="ASYNC" class="ch.qos.logback.classic.AsyncAppender">
  30. <discardingThreshold>0</discardingThreshold> <!-- 不丢失日志。默认的,如果队列的 80% 已满,则会丢弃 TRACT、DEBUG、INFO 级别的日志 -->
  31. <queueSize>512</queueSize> <!-- 更改默认的队列的深度,该值会影响性能。默认值为 256 -->
  32. <appender-ref ref="FILE"/>
  33. </appender>
  34. <!-- SkyWalking Appender:GRPC 日志收集,实现日志中心 -->
  35. <!--
  36. <appender name="SKYWALKING" class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.log.GRPCLogClientAppender">
  37. <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
  38. <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">
  39. <pattern>[%tid] ${FILE_LOG_PATTERN}</pattern>
  40. </layout>
  41. </encoder>
  42. </appender>
  43. -->
  44. <root level="INFO">
  45. <appender-ref ref="STDOUT"/>
  46. <!-- 本地环境下,如果不想【FILE】打印日志,可以注释掉本行 -->
  47. <appender-ref ref="ASYNC"/>
  48. <!-- 如果想接入【SkyWalking 日志服务】,可以取消注释掉本行 -->
  49. <!-- <appender-ref ref="SKYWALKING"/> -->
  50. </root>
  51. </configuration>