JMX(Java Management Extensions,即Java管理扩展)是一个为应用程序、设备、系统等植入管理功能的框架。
JMX 是Java Management Extension 的缩写,是 Java 应用程序的管理规范,可以实现应用程序,热插拔、热配置、热管理;
从原理上来说,JMX 只是高级的反射(reflection)库而已,高级的地方:
1、提供了对象的注册和缓存;
2、对注册的对象进行了分析,可以进行方法调用;
3、提供了附加的功能,如:loading,monitor,relation 等服务;
4、提供了统一的管理界面;
我们为什么要开发 JMX ?
JMX 的功能远超过了只是对组件进行管理而已,它的特性使它能够成为一个可配置和管理的软件的核心。这给长期处于混乱的基于component 集成这种开发模式提供一个统一的框架,也给基于internet 合作开发这样既需要分离,同时也需要协作的开发模式提供的一个选择方案。大家知道的 JBoss 就是采用 JMX 集成的,而在新的J2EE规范中,JMX规范已经成为其中的一员。
JMX中的术语:
- MBean:是Managed Bean的简称。在JMX中MBean代表一个被管理的资源实例,通过MBean中暴露的方法和属性,外界可以获取被管理的资源的状态和操纵MBean的行为。事实上,MBean就是一个Java Object,同JavaBean模型一样,外界使用自醒和反射来获取Object的值和调用Object的方法,只是MBean更为复杂和高级一些。
- MBeanServer:MBean生存在一个MBeanServer中。MBeanServer管理这些MBean,并且代理外界对它们的访问。并且MBeanServer提供了一种注册机制,是的外界可以通过名字来得到相应的MBean实例。
- JMX Agent:Agent只是一个Java进程,它包括这个MBeanServer和一系列附加的MbeanService。当然这些Service也是通过MBean的形式来发布。
- Protocol Adapters and Connectors
JMX Agent通过各种各样的Adapter和Connector来与外界(JVM之外)进行通信。同样外界(JVM之外)也必须通过某个Adapter和Connector来向JMX Agent发送管理或控制请求。
Adapter 和Connector的区别在于:Adapter是使用某种Internet协议来与JMX Agent获得联系,Agent端会有一个对象 (Adapter)来处理有关协议的细节。比如SNMP Adapter和HTTP Adapter。而Connector则是使用类似RPC的方式来访问Agent,在Agent端和客户端都必须有这样一个对象来处理相应的请求与应答。比如RMI Connector。
JMX Agent可以带有任意多个Adapter,因此可以使用多种不同的方式访问Agent。