SpringBoot——》配置logback日志文件

快来打我* 2024-02-18 13:29 146阅读 0赞

推荐链接:
总结——》【Java】
总结——》【Mysql】
总结——》【Redis】
总结——》【Kafka】
总结——》【Spring】
总结——》【SpringBoot】
总结——》【MyBatis、MyBatis-Plus】
总结——》【Linux】
总结——》【MongoDB】
总结——》【Elasticsearch】

SpringBoot——》配置logback日志文件

  • 一、application.yml
  • 二、logback-spring.xml

一、application.yml

  1. logging:
  2. # logback.xml配置文件的位置
  3. config: classpath:logback-spring.xml

二、logback-spring.xml

afe57d60960ff0dd151704f3ad96a42a.png

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE xml>
  3. <!-- 日志级别从低到高分为TRACE < DEBUG < INFO < WARN < ERROR < FATAL,如果设置为WARN,则低于WARN的信息都不会输出 -->
  4. <!-- scan:当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true -->
  5. <!-- scanPeriod:设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒。当scan为true时,此属性生效。默认的时间间隔为1分钟。 -->
  6. <!-- debug:当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false。 -->
  7. <configuration scan="true" scanPeriod="10 seconds">
  8. <property name="CONTEXT_NAME" value="facade-portal" />
  9. <property name="LOG_PATH" value="logs" />
  10. <property name="MAX_FILE_SIZE" value="100MB" />
  11. <property name="MAX_HISTORY" value="30" />
  12. <!--读取配置中心的属性 -->
  13. <!-- <springProperty scope="context" name="LOG_PATH_NAME" source="logging.file.name"/> -->
  14. <!-- <springProperty scope="context" name="springProfile" source="spring.profiles.active" defaultValue="dev"/> -->
  15. <contextName>${CONTEXT_NAME}</contextName>
  16. <!--输出到控制台 -->
  17. <!-- %m输出的信息,%p日志级别,%t线程名,%d日期,%c类的全名,%-5level:级别从左显示5个字符宽度,%logger{50}:表示logger名字最长50个字符,否则按照句点分割,%msg:日志消息,%i索引【从数字0开始递增】 -->
  18. <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
  19. <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
  20. <level>INFO</level>
  21. </filter>
  22. <encoder>
  23. <!--在控制台使用caller方式打印堆栈信息有超链接,使用replace去掉换行符-->
  24. <Pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %replace(%caller{1}){'\t|Caller.{1}0|\r\n', ''} -- %msg%n</Pattern>
  25. <!-- 设置字符集 -->
  26. <charset>UTF-8</charset>
  27. </encoder>
  28. </appender>
  29. <!--所有日志输出到文件 -->
  30. <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
  31. <!--日志名,指定最新的文件名,其他文件名使用FileNamePattern -->
  32. <File>${LOG_PATH}/${CONTEXT_NAME}.log</File>
  33. <!--日志文件输出格式 -->
  34. <encoder>
  35. <!--%logger{50}:表示logger名字最长50个字符,否则按照句点分割。
  36. %M:输出执行日志请求的方法名。尽量避免使用,除非执行速度不造成任何问题。
  37. %line:输出执行日志请求的行号。尽量避免使用,除非执行速度不造成任何问题。 -->
  38. <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{50}.%M\(%line\) -- %msg%n</pattern>
  39. <charset>UTF-8</charset> <!-- 设置字符集 -->
  40. </encoder>
  41. <!-- 日志记录器的滚动策略,按日期,按大小记录 -->
  42. <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
  43. <!-- 日志归档 后面可以加.zip -->
  44. <fileNamePattern>${LOG_PATH}/${CONTEXT_NAME}-%d{yyyy-MM-dd}-%i.log</fileNamePattern>
  45. <!--日志文件保留天数 -->
  46. <maxHistory>${MAX_HISTORY}</maxHistory>
  47. <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
  48. <!--文件达到 最大时会被压缩和切割 -->
  49. <maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
  50. </timeBasedFileNamingAndTriggeringPolicy>
  51. </rollingPolicy>
  52. </appender>
  53. <!-- ERROR 日志 -->
  54. <appender name="ERROR_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
  55. <!--日志名,指定最新的文件名,其他文件名使用FileNamePattern -->
  56. <File>${LOG_PATH}/${CONTEXT_NAME}-error.log</File>
  57. <encoder>
  58. <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{50}.%M\(%line\) -- %msg%n</pattern>
  59. <charset>UTF-8</charset> <!-- 此处设置字符集 -->
  60. </encoder>
  61. <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
  62. <fileNamePattern>${LOG_PATH}/${CONTEXT_NAME}_error-%d{yyyy-MM-dd}.log</fileNamePattern>
  63. <maxHistory>${MAX_HISTORY}</maxHistory>
  64. </rollingPolicy>
  65. <!-- 此日志文件只记录ERROR级别的 -->
  66. <filter class="ch.qos.logback.classic.filter.LevelFilter">
  67. <!-- 指定级别 -->
  68. <level>ERROR</level>
  69. <!-- onMatch:意思是>=指定级别 接受 -->
  70. <onMatch>ACCEPT</onMatch>
  71. <!-- onMismatch:意思是<指定级别 拒绝 -->
  72. <onMismatch>DENY</onMismatch>
  73. <!-- onMatch="ACCEPT" 表示匹配该级别及以上
  74. onMatch="DENY" 表示不匹配该级别及以上
  75. onMatch="NEUTRAL" 表示该级别及以上的,由下一个filter处理,如果当前是最后一个,则表 示匹配该级别及以上
  76. onMismatch="ACCEPT" 表示匹配该级别以下
  77. onMismatch="NEUTRAL" 表示该级别及以下的,由下一个filter处理,如果当前是最后一个,则不匹配该级别以下的
  78. onMismatch="DENY" 表示不匹配该级别以下的 -->
  79. </filter>
  80. </appender>
  81. <!-- 异步日志输出看情况配置 -->
  82. <appender name="ASYNC_FILE" class="ch.qos.logback.classic.AsyncAppender">
  83. <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
  84. <queueSize>512</queueSize>
  85. <!-- 添加附加的appender,最多只能添加一个 -->
  86. <appender-ref ref="FILE" />
  87. </appender>
  88. <appender name="ASYNC_ERROR_FILE" class="ch.qos.logback.classic.AsyncAppender">
  89. <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
  90. <queueSize>512</queueSize>
  91. <!-- 添加附加的appender,最多只能添加一个 -->
  92. <appender-ref ref="ERROR_FILE" />
  93. </appender>
  94. <!-- 统一配置日志输出,root标签和logger标签,如果这开启了就把不同环境的关上 -->
  95. <!-- root标签:相当于开关,只有把定义的appender添加到这里 才会生效有日志 -->
  96. <!-- <root level="INFO">
  97. <appender-ref ref="CONSOLE" />
  98. <appender-ref ref="ASYNC_FILE" />
  99. <appender-ref ref="ASYNC_ERROR_FILE" />
  100. </root> -->
  101. <!-- logger标签:用来设置某一个包或者具体的某一个类的日志打印级别 -->
  102. <!-- <logger name="com.test.springboot.admin" level="DEBUG" /> -->
  103. <!-- 配置不同环境的日志输出,root标签和logger标签 -->
  104. <springProfile name="dev">
  105. <logger name="com.test.dao" level="debug"/>
  106. <root level="DEBUG">
  107. <appender-ref ref="CONSOLE" />
  108. <appender-ref ref="ASYNC_FILE" />
  109. <appender-ref ref="ASYNC_ERROR_FILE" />
  110. </root>
  111. </springProfile>
  112. <springProfile name="prod">
  113. <root level="INFO">
  114. <appender-ref ref="ASYNC_FILE" />
  115. <appender-ref ref="ASYNC_ERROR_FILE" />
  116. </root>
  117. </springProfile>
  118. </configuration>

发表评论

表情:
评论列表 (有 0 条评论,146人围观)

还没有评论,来说两句吧...

相关阅读