`

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

阅读更多

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

日志记录不仅是开发和测试周期中的一个重要元素——提供要害调试信息,而且对于系统已部署到生产环境之后调试错误也是很有用的——提供修复错误所需的准确上下文信息。在本文中,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 类图
  

分享到:
评论

相关推荐

    简单架设Jabber-局域网即时通讯服务器.doc

    为了便于监控和调试,需要为Jabber Server创建专门的日志记录目录和进程状态文件目录。这两个目录应位于服务器上安全且容易访问的位置。 ##### 3.2 有关 MySQL 数据库的操作 在Jabber Server配置中,数据库操作是...

    YAJC: Yet Another Jabber Client-开源

    1. **changelog**:这是变更日志,记录了YAJC自上一版本以来的更新和改进,包括新功能、性能优化和已知问题修复等。通过阅读这个文件,用户可以了解软件的最新动态。 2. **YAJC.jar**:这是一个Java可执行文件,...

    即时通讯软件anyq服务器端源码

    4. **日志文件**: - `error.log`:记录服务器运行过程中的错误信息,对调试和故障排查至关重要。 - `record.log`:可能是服务器的活动记录,包含用户登录、消息发送等事件。 5. **其他文件**: - `README`:...

    RooyeeMessenger2.0(JabberIM 开源客户端)

    - `changelog.txt`:记录了软件的版本更新历史,展示了每次更新的功能改进和错误修复。 - `Runtime` 目录:可能包含了运行 Rooyee Messenger 2.0 所需的 Delphi 运行时库和组件。 - `Source` 目录:源代码存放的...

    即时通讯简单的例子

    - 此外,该示例还包含了基本的日志记录功能,有助于开发者调试和监控应用的行为。 通过以上解析可以看出,该示例提供了一个较为完整的基于XMPP协议的即时通讯客户端的实现方案,对于学习和理解XMPP协议以及Android...

    Asterisk Dialplan命令中文翻译

    7. Log:将信息记录到日志文件中。 8. JabberSend:通过Jabber即时通讯协议发送消息。 9. Page:在Asterisk 1.2版本后新增,用于广播到移动设备。 10. SendDTMF:发送双音多频(DTMF)信号,用于控制其他设备或服务...

    Hudson常用插件说明

    8. **Jabber Plugin**:集成Jabber即时消息协议至Hudson,需同时安装instant-messaging插件。 9. **Naginator Plugin**:构建失败后自动重试构建。 #### 构建工具插件 1. **Grails Plugin**:允许Hudson调用...

    openfire3.9.3源码

    10. **日志系统**:Openfire使用日志框架如Log4j来记录运行时信息,这对于调试和监控服务器状态非常有用。 11. **模块化架构**:Openfire采用模块化设计,每个核心功能如用户认证、群聊、传输等都是独立的模块,...

    smack4.1.x的完整依赖包

    4. **Log4j**: 日志记录框架,用于调试和监控 Smack 应用的运行状态。 5. **Java Cryptography Extension (JCE)**: 提供了加密算法,用于实现 TLS/SSL 加密。 **Android 兼容性** 由于 Smack 4.1.x 是为 Android ...

    smack-core-4.0.0.zip

    7. **错误排查与日志记录**: 掌握如何分析和解决在测试过程中遇到的问题,以及如何利用日志记录工具(如Logback或Log4j)收集和分析运行时信息。 总之,"smack-core-4.0.0.zip"和"common-jetty-testrunner.zip"的...

    tsung_user_guide

    #### 五、使用代理记录器 ##### 5.1 PostgreSQL - **记录器配置**:配置代理记录器以捕获PostgreSQL的交互细节。 ##### 5.2 HTTP和WEBDAV - **交互记录**:记录HTTP和WEBDAV的请求与响应信息。 #### 六、理解...

    Smack文档中文版

    例如,可以在Eclipse或IntelliJ IDEA中使用Smack的库,并利用日志工具(如Log4j)进行调试和问题排查。 **最佳实践** 1. 使用异步API以避免阻塞主线程。 2. 对于长连接,合理设置心跳间隔以保持连接活跃。 3. 使用...

    qsmack 源文件

    同时,QSmack 提供了详细的日志系统,通过配置 log4j 或其他日志框架,可以获取到详细的运行日志,这对于排查问题非常有帮助。 5. **社区支持** QSmack 作为一个开源项目,拥有活跃的社区和维护者。开发者可以在...

    tsung1.6.0

    4. **监控测试**:在测试过程中,使用`tsung log`命令查看实时性能数据。此外,还可以通过Web界面或命令行工具收集和分析结果。 5. **停止测试**:测试完成后,使用`tsung stop`命令结束测试,并使用`tsung status`...

    Jabberish-开源

    Jabber 协议,现在被称为 XMPP(Extensible Messaging and Presence Protocol),是一种实时通信协议,广泛应用于即时消息传递、在线状态检测以及多用户聊天室等功能。XMPP 基于 XML,允许服务器之间以及客户端之间...

    Jalli - an opensource chatlog converter-开源

    5. **版本更新与维护**:在提供的`CHANGELOG`文件中,可以找到关于Jalli的版本更新记录,包括新功能的添加、已知问题的修复以及性能优化等内容。这表明项目正在积极维护,用户可以期待未来的更新和改进。 6. **许可...

Global site tag (gtag.js) - Google Analytics