Java核心技术整理-日志篇


一、日志

10.1.1. Slf4j

slf4j 的全称是 Simple Loging Facade For Java,即它仅仅是一个为 Java 程序提供日志输出的统一接口,并不是一个具体的日志实现方案,就比如 JDBC 一样,只是一种规则而已。

所以单独的 slf4j 是不能工作的,必须搭配其他具体的日志实现方案。

比如 apache 的 org.apache.log4j.Logger,jdk 自带的java.util.logging.Logger 等。

10.1.2. Log4j

Log4j 是 Apache 的一个开源项目,通过使用 Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI 组件,甚至是套接口服务器、NT 的事件记录器、UNIX Syslog 守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。

Log4j 由三个重要的组成构成:日志记录器(Loggers),输出端(Appenders)和日志格式化器(Layout)。

  1. Logger:控制要启用或禁用哪些日志记录语句,并对日志信息进行级别限制。
  2. Appenders : 指定了日志将打印到控制台还是文件中。
  3. Layout : 控制日志信息的显示格式。

Log4j 中将要输出的 Log 信息定义了 5 种级别,依次为 DEBUG、INFO、WARN、ERROR 和 FATAL,当输出时,只有级别高过配置中规定的 级别的信息才能真正的输出,这样就很方便的来配置不同情况下要输出的内容,而不需要更改代码。

10.1.3.1. Logback 优点

  1. 同样的代码路径,Logback 执行更快。
  2. 更充分的测试。
  3. 原生实现了 SLF4J API(Log4J 还需要有一个中间转换层)。
  4. 内容更丰富的文档。
  5. 支持 XML 或者 Groovy 方式配置。
  6. 配置文件自动热加载。
  7. 从 IO 错误中优雅恢复。
  8. 自动删除日志归档。
  9. 自动压缩日志成为归档文件。
  10. 支持 Prudent 模式,使多个 JVM 进程能记录同一个日志文件。
  11. 支持配置文件中加入条件判断来适应不同的环境。
  12. 更强大的过滤器。
  13. 支持 SiftingAppender(可筛选 Appender)。
  14. 异常栈信息带有包信息。

写在最后

如果本文对你有帮助的话请给我点个赞再走吧。

猜你喜欢

转载自blog.csdn.net/qq_43055855/article/details/111998893