网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.Java动态程序设计——反射介绍.
.Javascript实例教程(20) OLE Aut.
.java与c#中二维数组的区别.
.静态库、动态连接库.
.Weblogic81和Hibernate 的集成问.
.wait,notify,sleep,join和线程同.
.用java输出杨辉三角形.
.TOMCAT3.1的安装与配置简要介绍.
.Java中的Stack.
.Java图像处理技巧四则.
.利用JMF进行多媒体编程.
.用Java制作十六进制编辑器.
.扩展ClassLoader定制类装载器.
.熟练掌握JDK1.5枚举类型.
.在你的JTextComponent组件中加入.
.applet 的参数化 -- 对数组进行初.
.Drive 对象.
.MVC 构架学习之渐行渐进(一).
.Java技术社区杂文 J2EE开发框架发.
.新手宝典 J2EE专家起步图解.

即时日志记录:使用 Jabber 增强 log4j 的功能

发表日期:2008-1-5


学习如何用自己的 appender 来扩展 log4j 框架

级别:高级

Ruth Zamorano (ruth.zamorano@orange-soft.com),软件架构师,Orange Soft
Rafael Luque (rafael.luque@orange-soft.com), CTO,Orange Soft

2003年 9 月

日志记录不仅是开发和测试周期中的一个重要元素——提供要害调试信息,而且对于系统已部署到生产环境之后调试错误也是很有用的——提供修复错误所需的准确上下文信息。在本文中,Orange Soft 公司(这是一家专业从事面向对象技术、服务器端Java 平台和 Web 可访问性的西班牙公司)的共同创办人 Ruth Zamorano 和 Rafael Luque 阐述了如何利用 log4j 的扩展能力,使得分布式 Java 应用程序能够通过即时消息传送(instant messaging,IM)来监视。

不管您编写多少设计良好的测试用例,即使是最小的应用程序也会在部署到生产环境之后隐藏着一个或多个错误。虽然测试驱动的开发和 QA 手段可以提高代码质量 并增强对应用程序的信心,但是当某个系统失败时,开发人员和系统治理员需要了解系统的相关执行上下文信息。有了适当的信息,他们就能确定问题的本质并快速解决问题,从而节省时间和金钱。

监视分布式应用程序要求能够对远程资源进行日志记录——通常是一台中心日志服务器或者系统治理员的计算机。log4j 环境提供一组适用于远程日志记录的 appender,比如 SocketAppenderJMSAppenderSMTPAppender。在本文中,我们将向您展示一种新的远程类(remote-class)appender:IMAppender

让我们首先简要回顾一下 log4j ,然后再深入研究 appender。自然地,理解 appender 的最好方式就是试着编写一个 appender,因此我们将在最后一节实现一个例子 IM(即时消息传送)appender,以说明 AppenderSkeleton 类的工作原理。

读者应该熟悉 log4j 框架。关于 log4j 的更多信息,请参见本文后面的 参考资料 。

log4j 概述
log4j 框架是用 Java 语言编写的事实上的标准日志记录框架。作为 Jakarta 项目的一部分,它在 Apache 软件许可证(Apache Software License)下分发,Apache 软件许可证是由开放源代码促进会(Open Source Initiative ,OSI)认证的一种流行的开放源代码许可证。log4j 环境是完全可配置的,或者通过编程方式完成,或者通过属性中的配置文件或者 XML 格式的配置文件完成。此外,它还答应开发人员无需修改源代码就可以选择性地筛选出日志记录请求。

log4j 环境包括三个主要组件:

  • logger(日志记录器):控制要启用或禁用哪些日志记录语句。可以对日志记录器指定如下级别:ALLDEBUGINFOWARNERROR, FATA或OFF

  • layout(布局):根据用户的愿望格式化日志记录请求。

  • appender:向目的地发送格式化的输出。

理解 appender
log4j 框架答应向任何日志记录器附加多个 appender。可以在任何时候对某个日子记录器添加(或删除)appender。附随 log4j 分发的 appender 有多个,包括:

  • ConsoleAppender
  • FileAppender
  • SMTPAppender
  • JDBCAppender
  • JMSAppender
  • NTEventLogAppender
  • SyslogAppender

也可以创建自己的自定义 appender。

log4j 最主要的特性之一就是它的灵活性。遗憾的是,没有多少现存文档说明了如何编写自己的 appender。学习编写 appender 的方式之一就是分析可用的源代码,然后尝试推断 appender 是如何工作的——本文将帮助 您完成这个任务。

揭开面纱
所有的 appender 都必须扩展 org.apache.log4j.AppenderSkeleton 类,这是一个抽象类,它实现了 org.apache.log4j.Appenderorg.apache.log4j.spi.OptionHandler 接口。AppenderSkeleton 类的 UML 类图看起来如图1所示:

图 1. AppenderSkeleton 的 UML 类图

上一篇:使用Hibernate来实现持久对象 人气:487
下一篇:JMS概述 人气:2024
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐