对logging类的认识
来源:互联网 发布:金庸群侠传mac脚本 编辑:程序博客网 时间:2024/04/29 23:05
在JDK1.4中提供了一个日志记录包:java.util.logging,它可以对程序中的日志记录进行相当复杂的控制。例如:通过它可以指定日志的级别和日志的位置(控制台、文件、套接字、内存缓冲区),也可以创建子记录器,通过它可以用程序控制的方式来指定想记录的内容,也可以使用配置文件来指定,而不需要去改动程序。和Log4j相比,它更简单更轻量级,在对日志输出的要求不是很复杂时,它无疑是更好的选择。
首先我们获得一个LogManager类的一个实例:
LogManager lMgr = LogManager.getLogManager();
然后我们创建记录器,并且把它添加到当前的管理器:
String thisName = “Logpkg”;
Logger log = Logger.getLogger(thisName);
lMgr.addLogger(log);
如果我们没有指定日志文件存放的位置,则按照jre/lib目录下logging.properties文件中指定的内容,默认是ConsoleHandler意味着日志信息在控制台显示。
在程序中我们可以按照级别发布日志信息,共有7个级别:SERVER(最高值),WARNING,INFO,CONFIG,FINE,FINER,FINEST(最低值),和OFF(不记录)。
log.server(“error”);
我们可以设置记录器的记录级别,以忽略低于WARNING级别的消息,只有用server和warning记录的信息才能输出。
log.setLevel(Level.WARNING);
log.info(“This message is info”);//这条信息会被忽略,不会被输出
log.warning(“This message is warning”);//这条信息会输出
Logger的名字可以是简单的文字,也可以是逗号分隔的复合名字,一个逗号左边名字相同但是逗号右边具有附加名字的记录器是原型记录器的子记录器,例如一个叫Logpkg的记录器和一个叫Logpkg.Test1的记录器。记录器和它的子记录器可以是不同的级别,在整个程序中可以只记录SERVER信息,对于一个可疑的部分,则可以记录其他更多的事件。
如果想要同时把日志输出到文件和控制台,可以创建一个FileHandler并把它添加到记录器。
fh = new FileHandler(“runtime.log”);
log.addHandler(fh);
如果没有特别指定,文件格式默认的是XML。
通过配置文件来控制日志记录:
FileInputStream fi = new FileInputStream(new File(logging.properties));
lMgr.readConfiguration(fi);
这样做的好处是不需要改变或重新编译程序,就可以改变日志记录的状态。
配置文件的格式:
handlers = java.util.logging.FileHandler,java.util.logging.ConsoleHandler
.Level = INFO
java.util.logging.ConsoleHandler.pattern = runtime.log
java.util.logging.ConsoleHandler.limit = 50000
java.util.logging.ConsoleHandler.count = 2
java.util.logging.ConsoleHandler.formatter = java.util.logging.XMLFormatter
java.util.logging.ConsoleHandler.level = WARNING
java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter
首先我们获得一个LogManager类的一个实例:
LogManager lMgr = LogManager.getLogManager();
然后我们创建记录器,并且把它添加到当前的管理器:
String thisName = “Logpkg”;
Logger log = Logger.getLogger(thisName);
lMgr.addLogger(log);
如果我们没有指定日志文件存放的位置,则按照jre/lib目录下logging.properties文件中指定的内容,默认是ConsoleHandler意味着日志信息在控制台显示。
在程序中我们可以按照级别发布日志信息,共有7个级别:SERVER(最高值),WARNING,INFO,CONFIG,FINE,FINER,FINEST(最低值),和OFF(不记录)。
log.server(“error”);
我们可以设置记录器的记录级别,以忽略低于WARNING级别的消息,只有用server和warning记录的信息才能输出。
log.setLevel(Level.WARNING);
log.info(“This message is info”);//这条信息会被忽略,不会被输出
log.warning(“This message is warning”);//这条信息会输出
Logger的名字可以是简单的文字,也可以是逗号分隔的复合名字,一个逗号左边名字相同但是逗号右边具有附加名字的记录器是原型记录器的子记录器,例如一个叫Logpkg的记录器和一个叫Logpkg.Test1的记录器。记录器和它的子记录器可以是不同的级别,在整个程序中可以只记录SERVER信息,对于一个可疑的部分,则可以记录其他更多的事件。
如果想要同时把日志输出到文件和控制台,可以创建一个FileHandler并把它添加到记录器。
fh = new FileHandler(“runtime.log”);
log.addHandler(fh);
如果没有特别指定,文件格式默认的是XML。
通过配置文件来控制日志记录:
FileInputStream fi = new FileInputStream(new File(logging.properties));
lMgr.readConfiguration(fi);
这样做的好处是不需要改变或重新编译程序,就可以改变日志记录的状态。
配置文件的格式:
handlers = java.util.logging.FileHandler,java.util.logging.ConsoleHandler
.Level = INFO
java.util.logging.ConsoleHandler.pattern = runtime.log
java.util.logging.ConsoleHandler.limit = 50000
java.util.logging.ConsoleHandler.count = 2
java.util.logging.ConsoleHandler.formatter = java.util.logging.XMLFormatter
java.util.logging.ConsoleHandler.level = WARNING
java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter
- 对logging类的认识
- 对类的认识
- 对抽象类的认识
- 对类的继承的基本认识
- 对DataSetHelper类的一些深刻认识
- 对java类中注释的认识
- 对Java类加载器的认识
- 对C++中派生类的认识
- 对C++中类模板的认识
- 对句柄的认识
- 对句柄的认识
- 对句柄的认识
- 对句柄的认识
- 对暂存器的认识
- 对const的认识
- 对引用的认识
- 对程序语言的认识
- 对数据仓库的认识
- Web应用时中文乱码的处理
- 新一代P2P网络电视PPlive试用
- 工作随笔(1)
- delphi在TreeView 里加复选框
- 无为而无不为——论老子哲学的深度悖论(转载)
- 对logging类的认识
- java实现FTP功能(源代码)
- 从JAR中读取GIF文件
- 将Java程序作成exe文件的几种方法
- 从JAR包中获取资源的方法
- 有效和正确定义hashCode()和equals()
- 高智能必须具备感情吗?
- 太岁
- 请问mstcpip.h和mstcpip.cpp两个文件哪里能找到啊