Logback浅析

电玩女神 2022-06-08 05:07 129阅读 0赞

1、Logback为取代log4j而生

  1. Logback是由log4j创始人Ceki Gülcü设计的又一个开源日志组件。logback当前分成三个模块:logback-core,logback- classiclogback-access

2、Logback的核心对象:Logger、Appender、Layout

  1. Logback主要建立于LoggerAppender Layout 这三个类之上。
  2. Logger:日志的记录器,把它关联到应用的对应的context上后,主要用于存放日志对象,也可以定义日志类型、级别。Logger对象一般多定义为静态常量,如:
  3. 1 package com.logs;
  4. 2
  5. 3 import org.slf4j.Logger;
  6. 4 import org.slf4j.LoggerFactory;
  7. 5
  8. 6 public class MyApp {
  9. 7 final static Logger logger = LoggerFactory.getLogger("MyApp.class");
  10. 8 public static void main(String[] args) {
  11. 9
  12. 10 logger.trace("trace");
  13. 11 logger.debug("debug str");
  14. 12 logger.info("info str");
  15. 13 logger.warn("warn");
  16. 14 logger.error("error");
  17. 15 }
  18. 16 }
  19. Appender:用于指定日志输出的目的地,目的地可以是控制台、文件、远程套接字服务器、 MySQL PostreSQLOracle和其他数据库、 JMS和远程UNIX Syslog守护进程等。
  20. Layout:负责把事件转换成字符串,格式化的日志信息的输出。具体的Layout通配符,可以直接查看帮助文档。

3、Level 有效级别

  1. Logger可以被分配级别。级别包括:TRACEDEBUGINFOWARNERROR,定义于ch.qos.logback.classic.Level类。程序会打印高于或等于所设置级别的日志,设置的日志等级越高,打印出来的日志就越少。如果设置级别为INFO,则优先级高于等于INFO级别(如:INFO WARNERROR)的日志信息将可以被输出,小于该级别的如DEBUG将不会被输出。为确保所有logger都能够最终继承一个级别,根logger总是有级别,默认情况下,这个级别是DEBUG

4、 三值逻辑

Logback的过滤器基于三值逻辑(ternary logic),允许把它们组装或成链,从而组成任意的复合过滤策略。过滤器很大程度上受到Linux的iptables启发。这里的所谓三值逻辑是说,过滤器的返回值只能是ACCEPT、DENY和NEUTRAL的其中一个。

如果返回DENY,那么记录事件立即被抛弃,不再经过剩余过滤器;

如果返回NEUTRAL,那么有序列表里的下一个过滤器会接着处理记录事件;

如果返回ACCEPT,那么记录事件被立即处理,不再经过剩余过滤器。

5、Filter 过滤器

  1. Logback-classic提供两种类型的过滤器:常规过滤器和TuroboFilter过滤器。Logback整体流程:Logger 产生日志信息;Layout修饰这条msg的显示格式;Filter过滤显示的内容;Appender具体的显示,即保存这日志信息的地方。

6、具体使用案例

  1. Java项目中一般都会应用比如strutsspringhibernate等开源框架,而这些框架很多是应用log4j记录日志的,所以我们考虑用[log4j][] \+ [slf4j][] \+ logback 。这样我们需要导入log4j-over-slf4j-1.6.4.jar logback-classic-1.0.1.jar logback-core-1.0.1.jar slf4j-api-1.6.4.jar ,如果你要用到EvaluatorFilter过滤器来过滤日志Msg中的特殊字符需要导入其依赖包[ janino-2.3.2.jar][janino-2.3.2.jar]。其logback.xml
  2. 1 <?xml version="1.0" encoding="UTF-8"?>
  3. 2 <configuration>
  4. 3
  5. 4 <!-- 控制台输出 -->
  6. 5 <appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
  7. 6 <encoder>
  8. 7 <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>
  9. 8 </encoder>
  10. 9 </appender>
  11. 10
  12. 11 <!-- 时间滚动输出 level DEBUG 日志 -->
  13. 12 <appender name="file—debug"
  14. 13 class="ch.qos.logback.core.rolling.RollingFileAppender">
  15. 14 <filter class="ch.qos.logback.classic.filter.LevelFilter">
  16. 15 <level>DEBUG</level>
  17. 16 <onMatch>ACCEPT</onMatch>
  18. 17 <onMismatch>DENY </onMismatch>
  19. 18 </filter>
  20. 19 <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
  21. 20 <FileNamePattern>D:/logs/debug.%d{yyyy-MM-dd}.log</FileNamePattern>
  22. 21 <MaxHistory>30</MaxHistory>
  23. 22 </rollingPolicy>
  24. 23 <encoder>
  25. 24 <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>
  26. 25 </encoder>
  27. 26 </appender>
  28. 27
  29. 28 <!-- 时间滚动输出 level ERROR 日志 -->
  30. 29 <appender name="file—error"
  31. 30 class="ch.qos.logback.core.rolling.RollingFileAppender">
  32. 31 <filter class="ch.qos.logback.classic.filter.LevelFilter">
  33. 32 <level>ERROR</level>
  34. 33 <onMatch>ACCEPT</onMatch>
  35. 34 <onMismatch>DENY </onMismatch>
  36. 35 </filter>
  37. 36 <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
  38. 37 <FileNamePattern>D:/logs/error.%d{yyyy-MM-dd}.log</FileNamePattern>
  39. 38 <MaxHistory>30</MaxHistory>
  40. 39 </rollingPolicy>
  41. 40 <encoder>
  42. 41 <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>
  43. 42 </encoder>
  44. 43 </appender>
  45. 44
  46. 45 <!-- 特定过滤含有某字符串的日志 -->
  47. 46 <appender name="file-str"
  48. 47 class="ch.qos.logback.core.rolling.RollingFileAppender">
  49. 48 <filter class="ch.qos.logback.core.filter.EvaluatorFilter">
  50. 49 <evaluator>
  51. 50 <expression>message.contains("str")</expression>
  52. 51 </evaluator>
  53. 52 <onMatch>ACCEPT</onMatch>
  54. 53 <onMismatch>DENY</onMismatch>
  55. 54 </filter>
  56. 55 <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
  57. 56 <FileNamePattern>D:/logs/contains.%d{yyyy-MM-dd}.log
  58. 57 </FileNamePattern>
  59. 58 <MaxHistory>30</MaxHistory>
  60. 59 </rollingPolicy>
  61. 60 <encoder>
  62. 61 <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>
  63. 62 </encoder>
  64. 63 </appender>
  65. 64
  66. 65 <!-- 数据库输出 -->
  67. 66 <appender name="db" class="ch.qos.logback.classic.db.DBAppender">
  68. 67 <connectionSource
  69. 68 class="ch.qos.logback.core.db.DriverManagerConnectionSource">
  70. 69 <driverClass>com.mysql.jdbc.Driver</driverClass>
  71. 70 <url>jdbc:mysql://host_name:3306/datebase_name</url>
  72. 71 <user>username</user>
  73. 72 <password>password</password>
  74. 73 </connectionSource>
  75. 74 </appender>
  76. 75
  77. 76 <logger name="java.sql.Connection">
  78. 77 <level value="DEBUG" />
  79. 78 </logger>
  80. 79 <logger name="java.sql.Statement">
  81. 80 <level value="DEBUG" />
  82. 81 </logger>
  83. 82 <logger name="com.ibatis">
  84. 83 <level value="DEBUG" />
  85. 84 </logger>
  86. 85 <logger name="com.ibatis.common.jdbc.SimpleDataSource">
  87. 86 <level value="DEBUG" />
  88. 87 </logger>
  89. 88 <logger name="com.ibatis.common.jdbc.ScriptRunner">
  90. 89 <level value="DEBUG" />
  91. 90 </logger>
  92. 91 <logger name="com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate">
  93. 92 <level value="DEBUG" />
  94. 93 </logger>
  95. 94 <logger name="com.danga.MemCached">
  96. 95 <level value="INFO" />
  97. 96 </logger>
  98. 97 <logger name="org.springframework.test">
  99. 98 <level value="DEBUG" />
  100. 99 </logger>
  101. 100 <logger name="org.apache.struts2">
  102. 101 <level value="DEBUG" />
  103. 102 </logger>
  104. 103
  105. 104 <root level="DEBUG">
  106. 105 <appender-ref ref="stdout" />
  107. 106 <appender-ref ref="file—debug" />
  108. 107 <appender-ref ref="file—error" />
  109. 108 <appender-ref ref="file-str" />
  110. 109 <appender-ref ref="db" />
  111. 110 </root>
  112. 111
  113. 112 </configuration>

发表评论

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

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

相关阅读

    相关 Logback浅析

    1、[Logback][]为取代[log4j][]而生      Logback是由log4j创始人Ceki Gülcü设计的又一个开源日志组件。logback当前分成三个模

    相关 Logback浅析

    1、[Logback][]为取代[log4j][]而生      Logback是由log4j创始人Ceki Gülcü设计的又一个开源日志组件。logback当前分成三个模