程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> JDBMonitor基本原理探究

JDBMonitor基本原理探究

編輯:關於JAVA

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等類。這些類采用了代理模式、裝飾者模式等設計模式,使得程序的可擴展性得到很大的提升。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved