JMX的全称为Java Management Extensions. 顾名思义,是管理Java的一种扩展。这种机制可以方便的管理正在运行中的Java程序。常用于管理线程,内存,日志Level,服务重启,系统环境等。
试想,一个正在运行中的程序,我们如果想改变程序中的一些属性,可以通过什么方法呢?可能有这么几个方法:
-
对于服务器式的程序,可以制作管理页面,通过HTTP post与servlet来更改服务器端程序的属性。
-
对于服务器式的程序,还可以通过SOAP方式。但这需要程序开启了SOAP端的服务。
-
可以使用RMI远程调用。但这需要设计开启RMI服务。
-
如果是SWT或Swing的程序,则可以通过设计UI管理界面,使用户可以和程序内部交互。
-
还有一种方式,是将可改变的属性放入配置文件XML,properties或数据库,程序轮询配置文件,以求获取最新的配置。
上面几个方法都是常见,但却无法通用的。所谓通用,是指解决方案符合一个标准,使得任何符合此标准的工具都能解析针对此标准的方案实现。这样A公司设计的方案,B公司可以根据标准来解析。JMX就是Java管理标准。
JMX的构成
JMX由三部分组成:
-
程序端的Instrumentation, 我把它翻译成可操作的仪器。这部分就是指的MBean. MBean类似于JavaBean。最常用的MBean则是Standard MBean和MXBean.
-
程序端的JMX agent. 这部分指的是MBean Server. MBean Server则是启动与JVM内的基于各种协议的适配器。用于接收客户端的调遣,然后调用相应的MBeans.
-
客户端的Remote Management. 这部分则是面向用户的程序。此程序则是MBeans在用户前投影,用户操作这些投影,可以反映到程序端的MBean中去。这内部的原理则是client通过某种协议调用agent操控MBeans.
JMX agent与Remote Management之间是通过协议链接的,这协议可能包含:
-
HTTP
-
SNMP
-
RMI
-
IIOP
JMX agent中有针对上面协议的各种适配器。可以解析通过相应协议传输过来的数据。Remote Management client则可以用现成的工具,如JConsole, 也可以自己书写java code。
接下来,我们看是一步一步,通过代码示例来熟悉JMX各种特性。
受监管的程序
JMX是用于管理java程序的,为了试验,我们首先需要写一个小程序Echo。然后加入JMX对此程序进行监管。这个程序就是每隔10秒钟,输出一个预先定义好的Message。
首先定义Message类。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
public
class
Message {
private
String title, body, by;
public
Message() {
title=
"none"
;
body=
"none"
;
by=
"none"
;
}
public
String getTitle() {
return
title;
}
public
void
setTitle(String title) {
this
.title = title;
}
public
String getBody() {
return
body;
}
public
void
setBody(String body) {
this
.body = body;
}
public
String getBy() {
return
by;
}
public
void
setBy(String by) {
this
.by = by;
}
public
void
echo() {
System.out.println(
"<"
+title+
">"
);
System.out.println(body);
System.out.println(
"by "
+ by);
}
}
|
定义Echo类
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
public
class
Echo {
public
static
Message msg =
new
Message();
public
static
boolean
running=
true
;
public
static
boolean
pause=
false
;
|