java.util.logging.Logger不是什麼新鮮東西了,1.4就有了,但是由於log4j的存在,這個logger一直沉默着,其實在一些測試性的代碼中,jdk自帶的logger比log4j更方便。
各級別按降序排列以下:
- SEVERE(最高值)
- WARNING
- INFO
- CONFIG
- FINE
- FINER
- FINEST(最低值)
此外,還有一個級別 OFF,可用來關閉日誌記錄,使用級別 ALL 啓用全部消息的日誌記錄。
logger默認的級別是INFO,比INFO更低的日誌將不顯示。
Logger的默認級別定義是在jre安裝目錄的lib下面。
# Limit the message that are printed on the console to INFO and above.
java.util.logging.ConsoleHandler.level = INFO
3、簡單實例
public
class TestLogger {
public
static
void main(String[] args) {
Logger log = Logger.getLogger(
"lavasoft");
log.setLevel(Level.INFO);
Logger log1 = Logger.getLogger(
"lavasoft");
System.out.println(log==log1);
//true
Logger log2 = Logger.getLogger(
"lavasoft.blog");
log2.setLevel(Level.WARNING);
log.info(
"aaa");
log2.info(
"bbb");
log2.fine(
"fine");
}
}
true
2009-7-28 20:00:30 TestLogger main
信息: aaa
Process finished with exit code 0
當註釋掉 log2.setLevel(Level.WARNING);
輸出結果:
true
2009-7-28 20:02:02 TestLogger main
信息: aaa
2009-7-28 20:02:02 TestLogger main
信息: bbb
Process finished with exit code 0
從這裏能夠看出,logger的名字是有層級關係的。這和log4j的控制方式徹底一致。
下面是API文檔的原文:
通常使用圓點分隔的層次命名空間來命名 Logger。Logger 名稱能夠是任意的字符串,可是它們通常應該基於被記錄組件的包名或類名,如 java.net 或 javax.swing。此外,能夠建立「匿名」的 Logger,其名稱未存儲在 Logger 命名空間中。
可經過調用某個 getLogger 工廠方法來得到 Logger 對象。這些方法要麼建立一個新 Logger,要麼返回一個合適的現有 Logger。
4、Logger的Handler
Handler 對象從 Logger 中獲取日誌信息,並將這些信息導出。例如,它可將這些信息寫入控制檯或文件中,也能夠將這些信息發送到網絡日誌服務中,或將其轉發到操做系統日誌中。
可經過執行 setLevel(Level.OFF) 來禁用 Handler,並可經過執行適當級別的 setLevel 來從新啓用。
Handler 類一般使用 LogManager 屬性來設置 Handler 的 Filter、Formatter 和 Level 的默認值。
java.util.logging.Handler
java.util.logging.MemoryHandler
java.util.logging.StreamHandler
java.util.logging.ConsoleHandler
java.util.logging.FileHandler
java.util.logging.SocketHandler
例子:
public
class TestLogger {
public
static
void main(String[] args)
throws IOException {
Logger log = Logger.getLogger(
"lavasoft");
log.setLevel(Level.INFO);
Logger log1 = Logger.getLogger(
"lavasoft");
System.out.println(log==log1);
//true
Logger log2 = Logger.getLogger(
"lavasoft.blog");
// log2.setLevel(Level.WARNING);
ConsoleHandler consoleHandler =
new ConsoleHandler();
consoleHandler.setLevel(Level.ALL);
log.addHandler(consoleHandler);
FileHandler fileHandler =
new FileHandler(
"C:/testlog%g.log");
fileHandler.setLevel(Level.INFO);
log.addHandler(fileHandler);
log.info(
"aaa");
log2.info(
"bbb");
log2.fine(
"fine");
}
}
輸出結果:
true
2009-7-28 20:36:14 TestLogger main
信息: aaa
2009-7-28 20:36:14 TestLogger main
信息: aaa
2009-7-28 20:36:14 TestLogger main
信息: bbb
2009-7-28 20:36:14 TestLogger main
信息: bbb
Process finished with exit code 0
查看C盤:
可見,默認的日誌方式是xml格式,很爛。因此最好自定義下logger的格式。須要用Formatter來定義。
5、Logger的Formatter
Formatter 爲格式化 LogRecords 提供支持。
通常來講,每一個日誌記錄 Handler 都有關聯的 Formatter。Formatter 接受 LogRecord,並將它轉換爲一個字符串。
有些 formatter(如 XMLFormatter)須要圍繞一組格式化記錄來包裝頭部和尾部字符串。能夠使用 getHeader 和 getTail 方法來得到這些字符串。
LogRecord 對象用於在日誌框架和單個日誌 Handler 之間傳遞日誌請求。
LogRecord(Level level, String msg)
用給定級別和消息值構造 LogRecord。
java.util.logging.Formatter
java.util.logging.SimpleFormatter
java.util.logging.XMLFormatter
看個例子就明白了:
public
class TestLogger {
public
static
void main(String[] args)
throws IOException {
Logger log = Logger.getLogger(
"lavasoft");
log.setLevel(Level.INFO);
Logger log1 = Logger.getLogger(
"lavasoft");
System.out.println(log == log1);
//true
Logger log2 = Logger.getLogger(
"lavasoft.blog");
// log2.setLevel(Level.WARNING);
ConsoleHandler consoleHandler =
new ConsoleHandler();
consoleHandler.setLevel(Level.ALL);
log.addHandler(consoleHandler);
FileHandler fileHandler =
new FileHandler(
"C:/testlog%g.log");
fileHandler.setLevel(Level.INFO);
fileHandler.setFormatter(
new MyLogHander());
log.addHandler(fileHandler);
log.info(
"aaa");
log2.info(
"bbb");
log2.fine(
"fine");
}
}
class MyLogHander
extends Formatter {
@Override
public String format(LogRecord record) {
return record.getLevel() +
":" + record.getMessage()+
"\n";
}
}