如鹏网 大学生计算机学习社区

CowNew开源团队

http://www.cownew.com 邮件请联系 about521 at 163.com

  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  363 随笔 :: 2 文章 :: 808 评论 :: 0 Trackbacks

JDBMonitor(可以从www.cownew.com下载)是一个非常强大的数据库监控、日志工具,它的无侵入性是它最大的特点。所谓无侵入性指的是无需编写代码就可以为系统增加数据日监控、日志功能。那么它到底是怎么实现的呢?咱们来探索一下它的基本原理。
要明白JDBMonitor的工作原理,必须首先弄明白JDBC驱动的工作原理:
所有的JDBC驱动都实现java.sql.Driver接口,此接口有两个重要方法:Connection connect(String url, java.util.Properties info),boolean acceptsURL(String url)。
JDBC中有个DriverManager类,它有一个重要方法,
registerDriver(java.sql.Driver driver)
所有的JDBC驱动都要调用此方法,这样才能将注册到驱动管理器中。
当用户调用DriverManager.getConnection("jdbc:......")的时候,DriverManager就把用户穿过来的连接字符串“jdbc:......”发给每个注册的驱动Driver的acceptsURL方法做为参数,驱动Driver就调用这个Driver的connect方法然后将方法的返回值直接做为自己的返回值。
更详细的解释请查看JDBC的JavaDoc,或者参考如下文章:http://www.cntopedu.cn/cntopedu_html_itxuetang/200562963708.asp


JDBMonitor写了自己的JDBCDriver:DBDriver,这个DBDriver识别所有以listenerconfig=开头的jdbc连接字符串,这样如果您修改了您系统的JDBC连接字符串并添加listenerconfig=等部分以后,此url就不会被您原来的JDBC驱动认识,耳反而被DBDriver认识,这样每次的数据库连接调用也都通过DBDriver以及相关的类来进行(比如DBPreparedStatement等),这些类首先先把通过的数据库调用记录下来,然后再转发给真正的数据库驱动,这样就达到了拦截任何JDBC调用的目的。更相信内容,请参考com.cownew.JDBMonitor.jdbc包下的DBDriver、DBConnection、DBStatement、DBPreparedStatement等类。这些类采用了代理模式、装饰者模式等设计模式,使得程序的可扩展性得到很大的提升。

COWNEW团队,最专业的开源团队!官方网站: www.cownew.com

posted on 2006-05-24 02:20 CowNew开源团队 阅读(940) 评论(1)  编辑  收藏

评论

# 请教中文乱码的问题 re: JDBMonitor基本原理探究[未登录] 2008-06-17 11:20 leon
您好:
搭建jdbmonitor成功后,用文件日志方式监听,但是所有的中文都是乱码,我用UltraEdit和记事本打开均是乱码。但是看log4j的日志,均无乱码。
做过以下尝试: 修改com.cownew.JDBMonitor.listenerImpl.FileDBListener.java,将 79行,即写日志文件之前
String s = info.toString();
改为
String s = new String(info.toString().getBytes(), "GBK");
还是没有用,请问这个是什么问题啊?
急盼答复,谢谢您!!

ps: 刚刚在留言板发了一条,可是提交之后就找不到了,只好再发一次,请见谅
  回复  更多评论
  


只有注册用户登录后才能发表评论。


网站导航: