Log4j学习—Log4j简介
一、 Log4j使用
1、 配置运行环境,包含log4j-1.2.9.jar,使用BasicConfigurator.configure()配置运行环境。
2、 使用Logger.getLogger(TestLogginLevel.class)获取Logger实例。
3、 使用fatal()、error()、warn()、info()、debug()打印Log。
二、 记录器(Logger)log4j允许程序员定义多个记录器,每个记录器有自己的名字,记录器之间通过名字来表明隶属关系(或家族关系)。
1、 Logger的层次结构。X.y的logger是x.y.z的logger的父logger,x是x.y.z的祖先logger.
Logger loggerX = Logger.getLogger(Y.class);
Logger loggerY = Logger.getLogger(X.class);取得的是同一个Logger实例。
2、 Logger的等级(Logger-Level filter)。如果Logger没有定义等级,则使用它父Logger的等级。根Logger的等级为DEBUG。
等级次序:OFF>FATAL>ERROR>WARN>INFO>DEBUG>ALL;
可以使用logger. setLevel(Level.DEBUG)设置Logger的等级。
等级过滤:如果执行等级<设定等级,则相应操作不会执行。
3、 基准过滤等级(Hierarchy-wide Threshold filter)。它有两种作用范围,全局范围和Appender范围,它的过滤级别高于实行等级。可以使用如下程序设置:
LoggerRepository repository = logger.getLoggerRepository();
repository.setThreshold(Level.OFF);
三、 存储器(Appenders):负责Log的保存。
1、 log4j中,log信息通过存放器输出到目的地。支持的存放器有console, files, GUI components, remote socket servers, JMS, NT Event Loggers, remote UNIX Syslog daemons。通过file存放器,log信息可以被输出到不同的文件中(即不同的目的地)。log信息可被异步存放。
2、 一个记录器可以有多个存放器,可以通过方法addAppender来增加存放器。一条blog信息如果可被这个记录器处理,则记录器会把这条信息送往每个它所拥有的存放器。
3、 每个记录器有一个继承开关,其开关决定记录器是/否继承其父记录器的存储器。可以使用setAdditivity()方法设置继承开关,默认为打开状态。
4、 Appender也可以设置过滤器,在配置文件中的属性为:Threshold。也可在程序中用setThreshold()方法设置,参数为Priority类的静态常量{FATAL,ERROR,WARN,INFO,DEBUG}。
5、 可以在一个Logger绑定两个同样的Appender。
四、 布局器(Layouts)布局负责格式化输出的log信息。log4j的PatternLayout可以让程序以类似C语言printf的格式化模板来定义格式。
五、 对象翻译器(Object Rendering),提供可插入式的对象翻译器,即将对象翻译为相应的消息。可以让你在不在对象类中添加toString()方法,而格式化类的信息。
1、 果想翻译的类实现了toString()方法,可以使用DefaultRenderer。
2、 自己的对象翻译器需要实现org.apache.log4j.or.ObjectRenderer接口。
3、 如果子对象没有相应的翻译器类,则会使用父类对应的翻译器类。
六、 Logger的执行时序。
1、 执行Hierarchy-wide Threshold过滤。
2、 执行Logger-Level过滤。
3、 生成LoggingEvent。
4、 调用Appender。
5、 调用Layout格式化LoggingEvent。
6、 返回格式化好的LoggingEvent,在Appender中执行相应的Log动作。
七、 性能(已经和System.out.println()差不多了)
1、 Logging关闭后的性能:应该在写Log之前判断isDebugEnabled()和相应的方法。优:可以省去一些对象调用toString()的时间。弊:当Logging打开时会做两次判断。
2、 如何Logging的性能:从继承的路径中寻找Appender是比较费时的,建议继承路径应该短点。
3、 Logging中的性能:操作文件系统等物理硬件是很费时的。
八、 XML配置文件
1、 Log4j首先查找默认的配置文件log4j.XML,如果没有找到就找log4j.properties。
2、 Log4j.xml只有Log4j1.2.7以后才支持,之前的版本只支持log4j.properties。
九、 重新读取配置文件。
1、 它是线程安全的。
2、 它并不是将上一次配置文件中的所有Appender、Logger删除,重新配置,而是指将在新的配置文件中涉及到的Appender关闭并删除。
3、 支持增量配置。注:不能再新的配置中涉及到已经配置的内容,一旦修改了某个Logger的配置可能关闭某些Appender。
十、 Log4j的配置
正如看到的,如果程序没有配置Log4j,他会报出一些Log4j没有初始化的错误,而用户可能并不愿意看到这类错误,这样可以通过如下的函数来解决:
static void turnOffLogging() {
Logger root = Logger.getRootLogger();
boolean rootIsConfigured = root.getAllAppenders().hasMoreElements();
if(!rootIsConfigured) {
root.setLevel(Level.OFF);
}
}
十一、 Sevlet中Log4j的配置
1、 建议将log4j-1.2.9.jar放在Web-INF/lib/目录下。配置文件放在WEB-INF/classes/目录下,这样没个应用可以是用独立的配置。当然,如果想在整个服务器上使用一种配置,可是将Log4j的配置,交给应用服务器如jBoss、weblogic等。
2、 如果无法确定在何处初始化Log4j,可是使用一个Sevlet做初始化工作。
Web.xml配置如下:
log4j-init
chapter3.Log4jInitServlet
log4j-init-file
WEB-INF/classes/log4j.properties
1
sevlet代码如下:
public void init() {
String prefix = getServletContext().getRealPath("/");
String file = getInitParameter("log4j-init-file");
//if the log4j-init-file is not set, then no point in trying
if(file != null) {
PropertyConfigurator.configure(prefix file);
}
}
上一篇: [java学习.载] Java学习从入门到精通.书籍篇
下一篇: Jdeveloper 实现Structs
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有