一个著名的日志系统Log4j

来源:互联网 发布:xmt什么意思网络用语 编辑:程序博客网 时间:2024/05/16 04:31

一、为什么要用日志系统

1、日志是个很重要的东西, 因为程序运行起来以后, 基本上就是一个黑盒子,如果程序的行为和预料的不一致,那就是出现Bug了,如何去定位这个Bug 呢?

2、如果没有日志系统只能有两种调试程序的方法:

  • 单步调试,一步步地跟踪,查看代码中变量的值, 这种办法费时费力, 并且只能在程序员的机器上才能用。

  • 在特定的地方打印日志, 通过日志的输出,帮助快速定位。

3、使用System.out.println去输出日志,把所有的信息都输出到控制台, 让那里变成了一堆垃圾。

二、日志系统的需求

  1. 日志消息除了能打印到控制台, 还可以输出到文件,甚至可以通过邮件发送出去(例如生成环境出错的消息)

  2. 日志内容应该可以做格式化, 例如变成纯文本,XML, HTML格式等等

  3. 对于不同的Java class,不同的 package , 还有不同级别的日志,应该可以灵活地输出到不同的文件中。
    例如对于com.foo 这个package,所有的日志都输出到 foo.log 文件中
    对于com.bar 这个package ,所有文件都输出到bar. log文件中
    对于所有的ERROR级别的日志,都输出到 errors.log文件中

  4. 能对日志进行分级, 有些日志纯属debug , 在本机或者测试环境使用, 方便程序员的调试, 生产环境完全不需要。有些日志是描述错误(error)的, 在生产环境下出错的话必须要记录下来,帮助后续的分析。

三、日志系统的设计

祭出“面向对象设计大法”,试图需求中抽象出一点概念。

1、针对“记录日志”的需求
首先要记录日志,肯定需要一个类来表达日志的概念,这个类至少应该有两个属性,一个是时间戳,一个是消息本身,把它叫做LoggingEvent吧,记录日志就像记录一个事件嘛。
其次是日志可以输出到不同的地方,控制台、文件、邮件等等, 这个可以抽象一下,不就是写到不同的目的地吗? 可以叫做LogDestination?

嗯, 还是简单一点,叫做Appender吧, 暗含了可以不断追加日志的意思。
这里写图片描述

2、针对日志内容格式化的需求
至于第二条的日志内容可以格式化,完全可以比葫芦画瓢, 定义一个Formatter接口去格式化消息。
这里写图片描述

对了, Appender 应该引用Formatter ,这样以来就可以对LoggingEvent记录格式化以后再发送。

3、针对日志可以灵活地输出到不同的文件中的需求
不同的class, package 输出的目的地不同? “目的地”这个概念是由Appender来表达的, 难道让不同的class, package 和Appender关联? 不不, 不能这样 !

还需要一个新的概念 , 这个概念是什么?

从用户角度想一下, 村民们要想获取日志,必须得先获取个什么东西,这个东西是不是可以称为Logger啊? 灵感的火花就闪了那么一下就被小张抓住了: 获取Logger的时候要传入类名或者包名!

原创粉丝点击