分享
 
 
 

使用WebLogicJMX进行定制调试

王朝other·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

维护复杂的遗留系统是一项挑战,而文档、理性设计以及编码实践的缺乏通常会使情况变得更为糟糕。遗憾的是,几乎所有的软件开发人员在其职业生涯中都会碰到此类任务。

对于任何使用数据库的应用程序,跟踪应用程序所生成的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;

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有