Log4j和JDBMonitor的比较
原创
©著作权归作者所有:来自51CTO博客作者cownew的原创作品,如需转载,请与作者联系,否则将追究法律责任
Log4j ([url]http://logging.apache.org/log4j/docs[/url])是一个开源代码的项目(Open source project),它使开发人员能最大限度的灵活控制程序调试信息的输出,这一点它是通过额外的配置文件实现的。
JDBMonitor([url]http://www.cownew.com[/url])是一个开源项目。使用它开发者可以很轻松为系统增加数据库执行日志功能。它使用十分方便,您所需要做的唯一事情就是在您系统的JDBC连接字符串前增加类似于 "listenerconfig=/config.xml:url=" 的字符即可,不用写任何代码。使用 JDBMonitor,您可以把数据库执行情况记录通过各种方式记录下来,比如打印到控制台、输出到文件或者通过socket传送给远程客户端。
共同点:
1、Log4j和JDBMonitor都有很强的可扩展性,例如Log4j可以写自己的Appender,JDBMonitor可以写自己的DBListener。
2、Log4j和JDBMonitor都很容易配置。当然Log4j配置文件相对复杂。
不同点:
1、Log4j能为各种事件进行日志输出,比如关键操作,运行中的变量值、数据库语句日志等。而JDBMonitor只能记录数据库sql语句操作记录。所以说Log4j应用范围更广,如果您需要记录非数据库语句日志就要使用Log4j,JDBMonitor则无能为力。
2、Log4j配置比较灵活,比如可以配置什么等级的日志被记录,记录的格式是什么样的,日志文件到多大的时候被转储;而JDBMonitor则相对较不灵活,输出格式比较单一、而且无法指定那些日志可以被忽略。
3、Log4j是侵入式的,所有的日志操作都是写在业务代码之中的,缺点是很明显的,这导致业务代码中掺杂大量的日志输出代码,降低了代码的可读性,而且一旦想去掉日志功能以后必须逐个删除代码,加大了工作量和风险。JDBMonitor是非侵入式的,它采用代理模式拦截对数据库的调用,然后对进行日志记录,业务系统中根本不用掺杂日志代码。只要修改JDBC连接字符串即可,如果想去掉日志功能,只要将JDBC连接字符串修改回去即可。
4、Log4j采用的日志记录实现方式会对程序的运行速度有一定影响,在日志比较多的时候,甚至会导致整个程序慢到无法忍受。而JDBMonitor则另起一个线程来记录SQL,所以它几乎不会对程序运行速度有任何影响。
5、Log4j的Appender不适合进行调试开发,调试开发只有那个控制台Appender可以用,但是在大数据量的时候整个屏幕狂刷不止,根本看不清,而且很多操作系统的控制台(比如windows的)都有缓冲区大小限制,所以很容易造成想看的sql日志被冲掉看不到了。而Log4j的不仅有与Log4j类似的控制台Appender可以用,而且有一个客户端SocketSwingClient可以用,这个客户端类似SQLServer的事件监听器,容纳的日志量相当大,而且可以自由控制日志的上下滚动。
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
SpringBoot集成Tess4J实现图片文字识别
SpringBoot集成Tess4J实现图片文字识别
SpringBoot Tess4j -
Log - Log4j - Apache Log4j概论
1. Log4j的类图Logger - 日志写出器,
java c/c++ Layout xml 构造方法 -
比较全的log4j示例
输出结果 如果想输出到tomcat根目录下,可以在路径前加上${sys:catalina.home}
spring sed apache -
[Log4j]--log4j日志管理
log4j日志记录实现
log4j apache properties文件 jar -
Log4j
日志是应用软件中不可缺少的部分,Apache的开源项目Log4j是一个功能强大的日志组件,提供方
apache java 配置文件 -
【日志框架】SLF4J教程、Log4j漏洞、Logback与log4j比较
一、参考资料SLF4J简介 -SLF4J教程™
slf4j log4j logback 配置详解 参考资料 -
log4j : Log4J 分包记录日志
...
操作系统 apache 日志文件 重新启动