JMX技术基础

JMX在J2SE 5和J2SE 6平台略有不同,我们基于J2SE 6来学习JMX。JMX已经成功Java 2平台的一部分,它的目标是动态管理和监控你所感兴趣的资源,例如应用程序、设备、服务、JVM等。JMX能够支持通过本地和远程访问的方式,来实现对相关资源的管理和监控。JMX只是对应用程序管理的扩展,而非必选,那么,如果我们选择为系统实现JMX管理功能,能够带来哪些好处呢?

第一、基于JMX来管理现有的Java应用程序,可以非常容易的基于Java技术实现,而无需更大的投入;

第二、JMX定义了一种规范和一组标准API,业界已经将JMX技术纳入到自己的产品中来,例如JBoss、Weblogic等;

第三、JMX具有一套标准的架构,使得在管理方面具备动态性、灵活性、可扩展性和稳定性;

第四、JMX可以非常容易地与其他管理方案进行整合,如通过浏览器来访问代理服务器(MBean Server)。

 

下面,我们看一下,JMX的技术架构,可以分为三层:

1、设备层

这一层定义了需要管理的资源,如应用程序、设备、服务、网络,将这些资源以Java对象的形式,以MBean的方式暴露管理接口,例如标准MBean,通过定义名称含有MBean后缀的管理接口,在实现这些接口时与待管理的资源相关联,之后将这些Java对象注册到代理服务器(MBean Server)来实现远程管理和监控。

例如,我们定义了一个标准MBean管理接口(其它MBean可以参考相关文档):

package org.shirdrn.java.jmx.standardmbean; public interface MyObjectMBean { public long getId(); public String getName(); public void setName(String name); public String show(); }

MBean的实现示例如下所示:

package org.shirdrn.java.jmx.standardmbean; import org.apache.log4j.Logger; public class MyObject implements MyObjectMBean { private static final Logger LOG = Logger.getLogger(MyObject.class); private long id; private String name; public MyObject() { super(); } public MyObject(long id, String name) { super(); this.id = id; this.name = name; } public long getId() { return id; } public void setId(long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String show() { StringBuffer sb = new StringBuffer().append("id=").append(id).append(", name=") .append(name); LOG.info("show()=" + sb.toString()); return sb.toString(); } }

可以看到,管理接口中暴露了4个方法,可以查看但不能修改id,可以查看并修改name,可以调用show方法。

需要注意的是,对于标准MBean,如果MBean管理接口定义为xxxMBean,则实现一定为xxx,否则就无法通过MBean Server查找到对应的资源。

2、代理层

代理层为待管理对象(如实现标准MBean管理接口的Java对象)提供了一个容器,其中只有满足要求并注册到容器中对象才能实现JMX管理。代理层最主要的组件就是MBean Server,它在我们的应用系统中充当一个管理功能的代理。

JavaSE 6平台中,可以通过调用ManagementFactory.getPlatformMBeanServer()来获取到一个MBean Server,然后向其中注册实现好的MBean资源,就能够通过JMX进行管理。

查找本地的MBean Server(如果没有找到,会自动创建一个),有关如何查找以及可能需要创建,可以通过ManagementFactory.getPlatformMBeanServer()的代码来实现跟踪。示例如下所示:

package org.shirdrn.java.jmx.standardmbean; import java.lang.management.ManagementFactory; import javax.management.InstanceAlreadyExistsException; import javax.management.MBeanRegistrationException; import javax.management.MBeanServer; import javax.management.MalformedObjectNameException; import javax.management.NotCompliantMBeanException; import javax.management.ObjectName; public class MyJMX { private static MBeanServer mBeanServer = null; static { if(mBeanServer==null) { mBeanServer = ManagementFactory.getPlatformMBeanServer(); } } public void register(Object objectMBean, ObjectName objectName) throws InstanceAlreadyExistsException, MBeanRegistrationException, NotCompliantMBeanException { mBeanServer.registerMBean(objectMBean, objectName); } public static void main(String[] args) throws InterruptedException, InstanceAlreadyExistsException, MBeanRegistrationException, NotCompliantMBeanException, MalformedObjectNameException, NullPointerException { MyJMX jmx = new MyJMX(); String objectNameString = "mydomain:mykey=MyObjectMBean"; ObjectName objectName = new ObjectName(objectNameString); MyObjectMBean myObjectMBean = new MyObject(299999007, "shirdrn"); jmx.register(myObjectMBean, objectName); Object lock = new Object(); synchronized (lock) { lock.wait(); } } }

在启动参数中,需要设置-Dcom.sun.management.jmxremote选项,表示可以通过远程进行管理。

3、远程管理层

我们要管理应用系统的某些资源,是通过代理层来间接实现管理,那么在与代理层之间交互最为直接,所以远程远程管理层定义了我们通过什么方式来与MBean Server进行交互,如基于何种协议、怎样建立连接才能通过远程手段在MBean Server的JVM之外进行访问,从而实现管理和监控,例如基于JMXMP、RMI等。

所以,远程管理层最重要的两个组件就是协议适配器和连接器。

Sun公司实现了一个基于JMXMP协议的工具JConsole,可以通过JConsole来方便地进行调试。启动JConsole后,可以通过本地进程或远程进程来进行远程管理。

例如,创建一个基于RMI协议的连接器,示例如下:

String serviceURL = "service:jmx:rmi:///jndi/rmi://localhost:1099/jmxrmi"; JMXServiceURL url = new JMXServiceURL(serviceURL); JMXConnectorServer connectorServer = JMXConnectorServerFactory.newJMXConnectorServer(url, null, mbeanServer);

 

参考链接:

http://download.oracle.com/javase/6/docs/technotes/guides/jmx/index.html

 

 

你可能感兴趣的:(java,String,server,J2SE,jmx,管理和监控)