JDK Logger的使用
Logger 日志记录对象,用于记录日志信息。
Handler 用于处理日志信息的输出,包括ConsoleHandler和FileHandler。注意必须关闭,否则可能会产生.lck文件。
LogRecord 含有调用信息、log、等级、样式等。
Formatter 通过formatMessage()组装log,format()组装最后的输出信息格式。
Logger是通过StackTraceElement来实现调用信息打印的:
StackTraceElement stack[] = (new Throwable()).getStackTrace();
for (int i = 0; i < stack.length; i++) {
StackTraceElement ste = stack[i];
System.out.println(i + ": "+ste.getClassName());
System.out.println(i + ": "+ste.getMethodName());
System.out.println(i + ": "+ste.getFileName());
System.out.println(i + ": "+ste.getLineNumber());
}
Logger所对应的属性文件在安装jdk目录下的jre/lib/logging.properties
Level:用于表示日志的级别。JDK 日志框架默认有如下级别 : SEVERE,WARNING,INFO,CONFIG,FINE,FINER,FINEST.
Logger处理流程如下图所示:

Logger 对象首先会判断日志的级别是否满足输出级别的要求,然后将满足级别要求的日志消息交给所配置的 Handler 对象来处理,如果日志对象配置了一个 Filter 对象。那么 Filter 对象将会对日志信息做一次过滤。 Handler 对象接受到日志消息后,根据其所配置的格式化类 Formatter 来改变日志的格式。根据所配置的 Filter 对象和 Level 对象来再次过滤日志信息,最后输出到该种 Handler 对象所指定的输出位置中,该输出位置可以是控制台,文件,网络 socket 甚至是内存缓冲区。
JDK Logger 日志系统详解
本文详细介绍了JDK内置的Logger日志系统的使用方法,包括日志记录对象Logger、日志信息处理组件Handler、日志记录内容LogRecord、日志格式化组件Formatter以及日志过滤机制等核心组成部分。此外还解释了Logger的处理流程和日志级别。
327





