日期:2010-07-29 浏览次数:21266 次
一、创建Web应用的管理系统
对Web应用构建一个基于JMX的管理系统,我们需要做的事情有哪些呢?
针对每一个需要管理的资源创建一个MBean的实例,这是JMX框架所要求的,有两种类型的实例可供选择,一种是直接管理资源的MBean,一种通过调用资源实例进行管理的MBean。
编写一个MBean描述文件,并描述每一个MBean,选择基于XML的MBean描述文件是一个不错的决定。
通过读MBean描述文件,生成MBeanInfo,从而生成一个个MBean。
将需要进行管理的MBean注册到MBean Server当中。
编写客户端代码,选择Web的方式进行客户端的编码比较Web应用的风格,也比较容易实现。
那么一个基于JMX的Web应用的管理框架已经成形,图3是它的基本结构图,虚线部分为基于JMX的管理系统。接下来我们按照步骤实现整个管理系统。
二、获得MBeanServer的实例
有两种方案获得MBeanServer的实例。
1、通过获得Web服务器的MBeanServer的实例,这样做的好处是通过该MBeanServer对本身,甚至可以实现对Web服务器的自身的一些管理。Tomcat的管理框架也是建立JMX的基础上,它使用的JMX的实现是MX4J,这是一个非常优秀的JMX开源项目,在tomcat4.1.27中,MBeanServer的实例存放与属性名为"org.apache.catalina.MBeanServer"的application变量(Web应用中变量的几种范围:page,request,session,application)中,因此servlet中获得MBeanServer实例的办法:
server = (MBeanServer) getServletContext().getAttribute("org.apache.catalina.MBeanServer");
如果通过这种方式,你获得的server为null,这说明你必须还要完成下面的工作,使你能够有权限获得系统的MBeanServer,tomcat才会将MBeanServer的实例存放在web应用程序下属性名"org.apache.catalina.MBeanServer"的系统变量中。
找到tomcat下conf目录,修改server.xml文件。修改Web应用的context元素,添加上privileged="true"这一项属性即可,例如:
<Context path="/myapp" docBase="c:/web/" debug="9" privileged="true" reloadable="true" crossContext="true"/>
2、通过JMX API中MBeanServerFactory类的createMbeanServer()的方法创建MBeanServer的实例,这样做得好处的使JMX的实现与Web服务器无关,使代码的移植性更强。在创建完MBeanServer以后,为了让能够在管理系统中很方便的获得该MBeanServer的引用,可将其置入application变量中(推荐),或者使用singleton设计模式的方法创建和获得。
使用JMX API创建MBean Server的代码如下:
MBeanServer server = MBeanServerFactory.createMBeanServer();
究竟采取何种方案获得MBeanServer并不十分重要,可以考虑实现的方便进行选择。
三、创建MBean
为了能够管理Web应用的资源,首先要使资源能够被管理,按照JMX规范的要求,我们将资源封装成MBean,实际上也就是为Web应用添加可管理性。
获得MBeanServer的实例以后,就可以编写自己的MBean了,根据JMX的规范,MBean有标准的和动态的两种主要类型,这里就不赘述了,具体可以参看JMX的规范(http://)。有两种用于特殊用途的动态 MBeans:模型MBean和开放MBean。模型 MBean (Modle MBean)提供了"现成的"MBean 实现,您可以使用它来快速地利用任何 JMX 可管理资源。它是预制的、通用的和动态的 MBean 类,并且提供了参考实现,已经包含了所有必要缺省行为的实现 - 允许您在运行时添加或覆盖需要定制的那些实现。这使得基于 Java 的、非工具化的资源能够在运行时提供保证兼容的 MBean 虚包,使它们能够通过 JMX 体系结构进行管理。
在Web应用中,资源是多元化,有运行实例,静态文件,甚至是设备或者是硬件状态,那么我们把这些资源可以分为两类,一些资源需要进行动态的管理监控(如登陆用户数,数据库连接监控,即时日志等),一些则是静态资源,只需要进行静态的管理(系统配置文件,日志级别等),要管理这些不同类型的资源,这就要求MBean一方面能够直接调用运行实例提供的接口进,另一方面又希望MBean自身能够提供静态资源的管理,模型MBean能够很好的满足这样