維護復雜的遺留系統是一項挑戰,而文檔、理性設計以及編碼實踐的缺乏通常會使情況變得更為糟糕。遺憾的是,幾乎所有的軟件開發人員在其職業生涯中都會碰到此類任務。
對于任何使用數據庫的應用程序,跟蹤應用程序所生成的SQL語句是非常有益的。這樣的跟蹤有助于分析性能瓶頸和調試錯誤,還可以幫助開發人員了解與應用程序相關的業務流程。
對于遺留的應用程序,我們希望可以進行這樣的跟蹤而不必修改任何代碼或應用程序配置。利用WebLogic的JMX API,我們可以快速地編寫出跟蹤大型復雜遺留應用程序的JDBC調用的少量代碼,而不會對現有代碼和應用程序配置產生影響。此外,這種小項目有助于我們理解JMX以及在幕后WebLogic是如何使用JMX的。在本文中,我將展示利用WebLogic JMX跟蹤SQL語句的細節。
什么是JMX?
JMX全稱為java Management Extensions(Java治理擴展)。MBean(即managed bean,托管bean)是可以通過JMX API進行治理的資源。大多數應用服務器使用JMX來提供治理控制臺并治理資源。此外,應用程序開發人員可以在他們的定制應用程序中使用JMX來提供治理和審計功能。
WebLogic的JMX實現為開發人員和治理員提供了哪些優點?
WebLogic Server使用JMX MBeans進行配置和治理。每個WebLogic Server會有一個自己的MBean的副本,它由治理服務器負責更新。治理服務器維護它所治理的所有服務器的MBeans的正本。一旦治理服務器發生故障,托管服務器將根據本地的MBean副本運行,直到治理服務器可以再次更新該服務器的本地MBean。
WebLogic不僅提供了一個使用JMX MBeans的治理控制臺,它還提供了一個API以便答應應用程序開發人員配置和研究WebLogic資源。利用WebLogic JMX的最輕易的方式就是使用WebLogic控制臺來更改WebLogic資源的配置,以及查看控制臺中的技術指標。雖然WebLogic控制臺的監控和配置功能相當強大,可以滿足運行在WebLogic上的大多數應用程序的需要,WebLogic JMX API還是提供了一種更為強大的工具來治理運行在WebLogic平臺上的應用程序。WebLogic JMX API的使用使得配置和擴展WebLogic資源成為可能,還可以從WebLogic的子系統接收通知。例如,一個JDBC連接的最小和最大數設為n的應用程序可能希望有一個監聽器,以便監聽來自WebLogic JMX MBeans的通知,并且在有n-x個并發JDBC連接使用應用程序時,會向治理員發送電子郵件,從而使治理員可以決定增加n值并重新配置JDBC連接池(這里x是一個由治理員決定的任意數字)。應用程序開發人員進一步使用JMX的例子包括WebLogic子系統中的跟蹤事件,包括EJB事件和服務器啟動/停止事件。
在分析JDBC語句方面,WebLogic應用程序中有哪些可用選項?
在WebLogic應用程序中,有多種技術可以用來創建對JDBC語句的動態跟蹤。為來自java.sql包的Statement、PReparedStatement和CallableStatement類創建子類,以便使用Log4J或WebLogic記錄之類的記錄系統打印跟蹤信息,然后在應用程序中使用這些子類,這是一個可行方案,但是并不適用于遺留代碼。也可以使用類似于TOAD的工具來實現這種跟蹤,但是此類工具對于應用程序開發人員而言可能不輕易得到,而且可能無法提供所需的全部信息。AOP技術是打印JDBC語句的另一種可行方案。然而在撰寫本文時,BEA WebLogic還沒有正式支持AOP,盡管關于WebLogic AOP的文章已經在dev2dev網站上出現。在撰寫本文時,在WebLogic上實現AOP也并不是一項輕而易舉的任務。使用WebLogic 6.1或8.1的WebLogic JMX不需要使用任何附加的類庫和配置,因為所需的所有類均可在weblogic.jar中得到,而且代碼實現起來相當簡單。況且WebLogic JMX是一項非常成熟的技術,可以通過不改變任何核心應用程序代碼或者字節碼來實現。
使用WebLogic JMX API
WebLogic javadoc可以通過http://e-docs.bea.com/wls/docs81/javadocs/在線獲得。該API包括幾個名稱中包含management的包,這些包就是WebLogic的JMX實現(參見表1)。
使用JMX跟蹤JDBC調用
一種編寫跟蹤代碼并提供一個用戶界面來查看SQL的簡單方法是編寫一個jsp、一個Servlet以及一個Java Bean或對象。我們將展示bean/POJO的全部細節,而省去用戶界面/控制器方面的大多數細節,因為大多數WebLogic開發人員對此已有很深的了解。注重,無需修改任何部署描述符、數據庫連接池或數據源來實現跟蹤,所有對應用程序的更改將在運行時進行。
步驟1
首先我們將創建一個名為MyTracerBean.java的類,并導入所需的WebLogic JMX包和類。
import javax.naming.Context;
import weblogic.jndi.Environment;
import weblogic.management.MBeanHome;
import weblogic.management.configuration.JDBCConnectionPoolMBean;
import weblogic.management.runtime.JDBCStatementProfile;
import weblogic.management.runtime.JDBCConnectionPoolRuntimeMBean;
import javax.management.InstanceNotFoundException;
import javax.management.InvalidAttributeValueException;
import javax.naming.NamingException;
新聞熱點
疑難解答