logback-spring.xml 4.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <configuration scan="true" scanPeriod="60 seconds" debug="false">
  3. <contextName>logback</contextName>
  4. <property name="logback.logdir" value="./log/"/>
  5. <property name="logback.appname" value="java"/>
  6. <!--输出到控制台 ConsoleAppender-->
  7. <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
  8. <!--展示格式 layout-->
  9. <layout class="ch.qos.logback.classic.PatternLayout">
  10. <pattern>%d [%thread] %-5level %logger{36} %line : %msg%n</pattern>
  11. </layout>
  12. </appender>
  13. <appender name="fileInfoLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
  14. <!--如果只是想要 Info 级别的日志,只是过滤 info 还是会输出 Error 日志,因为 Error 的级别高,
  15. 所以我们使用下面的策略,可以避免输出 Error 的日志-->
  16. <filter class="ch.qos.logback.classic.filter.LevelFilter">
  17. <!--过滤 Error-->
  18. <level>ERROR</level>
  19. <!--匹配到就禁止-->
  20. <onMatch>DENY</onMatch>
  21. <!--没有匹配到就允许-->
  22. <onMismatch>ACCEPT</onMismatch>
  23. </filter>
  24. <!--日志名称,如果没有File 属性,那么只会使用FileNamePattern的文件路径规则
  25. 如果同时有<File>和<FileNamePattern>,那么当天日志是<File>,明天会自动把今天
  26. 的日志改名为今天的日期。即,<File> 的日志都是当天的。
  27. -->
  28. <File>${logback.logdir}/info.${logback.appname}.log</File>
  29. <!--滚动策略,按照时间滚动 TimeBasedRollingPolicy-->
  30. <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
  31. <!--文件路径,定义了日志的切分方式——把每一天的日志归档到一个文件中,以防止日志填满整个磁盘空间-->
  32. <FileNamePattern>${logback.logdir}/info.${logback.appname}.%d{yyyy-MM-dd}.log</FileNamePattern>
  33. <!--只保留最近90天的日志-->
  34. <maxHistory>90</maxHistory>
  35. <!--用来指定日志文件的上限大小,那么到了这个值,就会删除旧的日志-->
  36. <!--<totalSizeCap>1GB</totalSizeCap>-->
  37. </rollingPolicy>
  38. <!--日志输出编码格式化-->
  39. <encoder>
  40. <charset>UTF-8</charset>
  41. <pattern>%d [%thread] %-5level %logger{36} %line : %msg%n</pattern>
  42. </encoder>
  43. </appender>
  44. <appender name="fileErrorLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
  45. <!--如果只是想要 Error 级别的日志,那么需要过滤一下,默认是 info 级别的,ThresholdFilter-->
  46. <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
  47. <level>Error</level>
  48. </filter>
  49. <!--日志名称,如果没有File 属性,那么只会使用FileNamePattern的文件路径规则
  50. 如果同时有<File>和<FileNamePattern>,那么当天日志是<File>,明天会自动把今天
  51. 的日志改名为今天的日期。即,<File> 的日志都是当天的。
  52. -->
  53. <File>${logback.logdir}/error.${logback.appname}.log</File>
  54. <!--滚动策略,按照时间滚动 TimeBasedRollingPolicy-->
  55. <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
  56. <!--文件路径,定义了日志的切分方式——把每一天的日志归档到一个文件中,以防止日志填满整个磁盘空间-->
  57. <FileNamePattern>${logback.logdir}/error.${logback.appname}.%d{yyyy-MM-dd}.log</FileNamePattern>
  58. <!--只保留最近90天的日志-->
  59. <maxHistory>90</maxHistory>
  60. <!--用来指定日志文件的上限大小,那么到了这个值,就会删除旧的日志-->
  61. <!--<totalSizeCap>1GB</totalSizeCap>-->
  62. </rollingPolicy>
  63. <!--日志输出编码格式化-->
  64. <encoder>
  65. <charset>UTF-8</charset>
  66. <pattern>%d [%thread] %-5level %logger{36} %line : %msg%n</pattern>
  67. </encoder>
  68. </appender>
  69. <!--指定最基础的日志输出级别-->
  70. <root level="INFO">
  71. <!--appender将会添加到这个loger-->
  72. <appender-ref ref="console"/>
  73. <appender-ref ref="fileInfoLog"/>
  74. <appender-ref ref="fileErrorLog"/>
  75. </root>
  76. </configuration>