您的位置:首页 > 编程语言 > Java开发

Java之JMX

2015-12-22 11:55 239 查看
http://www.cnblogs.com/itech/archive/2010/09/16/1827999.html

[动态修改程序的配置的思想值得学习!]



一、JMX简介

  JMX是一种J***A的正式规范,它主要目的是让程序有被管理的功能,那么怎么理解所谓的“被管理”呢?试想你开发了一个软件(如WEB网站),它是在24小时不间断运行的,那么你可能会想要“监控”这个软件的运行情况,比如收到了多少数据,有多少人登录等等。或者你又想“配置”这个软件,比如现在访问人数比较多,你想把数据连接池设置得大一些。

  当然,你也许会专门为这些管理来开发软件,但如果你借助JMX,则会发现创建这样的管理程序是如此简单。因为你无需为管理程序来开发界面,已经有通用的JMX管理软件,如MC4J,或者是用一般都附带提供的HTML网页来管理,你要做的仅仅是将自己要被管理和监控类的按照JMX规范修改一下即可。

  中间件软件WebLogic的管理页面就是基于JMX开发的,而JBoss则整个系统都基于JMX构架。



二、准备工作

  JMX是一份规范,SUN依据这个规范在JDK(1.3、1.4、5.0)提供了JMX接口。而根据这个接口的实现则有很多种,比如Weblogic的JMX实现、MX4J、JBoss的JMX实现。在SUN自己也实现了一份,不过在JDK1.4之前,这件JMX实现(一些JAR包)是可选的,你得去它的网站上下载。JDK5.0则内嵌了进来,安装JDK5.0就可以开发基于JMX的代码了。

  但JDK5.0并非包含所有SUN的关于JMX的代码,有一些工具类是排除在JDK5.0之外的。下面根据所使用的JDK版本情况,谈一谈开发环境的准备。

1、JDK1.3、1.4

  去SUN网站下载SUN的JMX实现,共两个ZIP文件,下载网址:http://java.sun.com/products/JavaManagement/download.html。

(1)jmx-1_2_1-ri.zip

   解压后的lib目录包含:jmxri.jar、jmxtools.jar

(2)jmx_remote-1_0_1_03-ri.zip

   解压后的lib目录包含:jmxremote.jar、jmxremote_optional.jar、rmissl.jar

  如果在DOS下用命令行开发,则把这五个JAR包加入到classpath系统变量中。如果你用Eclipse开发,则把JAR包加入到项目属性的Libratries(库)引用中。

2、JDK5.0

  JDK5.0的jre\lib\rt.jar已经包含了jmxri.jar、jmxremote.jar、rmissl.jar三个包的代码。如果你用到jmxtools.jar、jmxremote_optional.jar的类,则需要将这两个类加入到classpath或 Eclipse的项目库引用中。

3、我使用的开发环境:JDK5.0 + Eclipse3.2。

  注:因为用到jmxtools.jar中的HtmlAdaptorServer类,所以将此包加入到项目库引用中。jmxremote_optional.jar暂时不用到,不管它。

三、HelloWorld实例

1、Hello是一个需要被管理的类(普通类)



/**

* @author ChenGang 2005-12-3

*/

public class Hello implements HelloMBean {

private String name;

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public void printHello() {

System.out.println("Hello World, " + name);

}

public void printHello(String whoName) {

System.out.println("Hello , " + whoName);

}

}





2、要管理Hello则必须创建一个相应MBean,如下:



/**

* @author ChenGang 2005-12-3

*/

public interface HelloMBean {

public String getName();

public void setName(String name);

public void printHello();

public void printHello(String whoName);

}






说明:包含在MBean中方法都将是可以被管理的。MBean起名是有规范的,就是原类名后加上MBean字样。

 

3、创建一个Agent类




import javax.management.MBeanServer;

import javax.management.MBeanServerFactory;

import javax.management.ObjectName;

import com.sun.jdmk.comm.HtmlAdaptorServer;

public class HelloAgent {

public static void main(String[] args) throws Exception {

MBeanServer server = MBeanServerFactory.createMBeanServer();

ObjectName helloName = new ObjectName("chengang:name=HelloWorld");

server.registerMBean(new Hello(), helloName);

ObjectName adapterName = new ObjectName("HelloAgent:name=htmladapter,port=8082");

HtmlAdaptorServer adapter = new HtmlAdaptorServer();

server.registerMBean(adapter, adapterName);

adapter.start();

System.out.println("start.....");

}

}





说明:

* 先创建了一个MBeanServer,用来做MBean的容器

* 将Hello这个类注入到MBeanServer中,注入需要创建一个ObjectName类

* 创建一个AdaptorServer,这个类将决定MBean的管理界面,这里用最普通的Html型界面。AdaptorServer其实也是一个MBean。

* chengang:name=HelloWorld的名字是有一定规则的,格式为:“域名:name=MBean名称”,域名和MBean名称都可以任意取。

4、运行HelloAgent,然后打开网页:http://localhost:8082/ , 单击“name=HelloWorld”链接进入。



转自:http://www.blogjava.net/hengheng123456789/articles/65690.html

------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
http://bhsc-happy.iteye.com/blog/678163

我的理解--关于jmx

博客分类:
java live

OSGI应用服务器JBossJVMWeb

JMX

Java Management Extensions,Java管理扩展,初步看了些资料,以为是专门管理,监控jvm的一些信息的,特别是visual VM这个监控jvm的东西,还有一个添加JMX连接的时候(我自己想错了,那样的话应该叫jvm Management Extensions),其实他能使得基于java语言开发的程序能被管理,并且是可扩展的。









Jdk以前是通过JVMPI之类来监测Java程序运行中的jvm和系统的一系列情况,现在通过jmx就可以做到,这是通过java.lang.management 包来实现的,这个包是 JMX 在 JDK方面 的一个应用,并不是表示jmx就是一个监控jvm的东西。



我们可以用jmx来监控我们的系统,通过公布API的方式,但是,这里采用监控这个词,也是受了前面的例子的影响,实际上,个人觉得,就可以用jmx来开发我们的系统。



现在的jboss,hibernate,tomcat各种应用都号称实现了JMX规范,将可管理,可调用的MBean注册到MBeanServer中,通过一种类似“web服务”的方式公布出去,并且伴有一个名字,可以通过该名字找到该MBean。并且,这里的MBean是可以被管理的,说到这里又想到了OSGI。



JMX与Web Service



个人认为,我们实现JMX规范,将东西发布出去,和通过web Service的方式是很类似的,也是可以远程调用的,只是相对的web Service的方式更加SOA一些,不过JMX号称也要提供对非java客户端的支持,也就是跨语言了吧。。。



现在的JMX连接方式:

JMXServiceURL url = new JMXServiceURL("service:jmx:rmi:///jndi/rmi://localhost:9999/server"); JMXConnector jmxc = JMXConnectorFactory.connect(url, null);

看了下源码,貌似还是通过RMI来实现的,不知道它要怎么实现非java客户端支持。





从这里,我觉得JMX可以实现的,我们也都可以通过web Service实现,只是看在它有个“M”上,以后如果有什么系统管理,监控方面的,可以考虑使用它,也许开发,个人觉得还是使用web service好一些。



说到这里,感觉OSGI与JMX也好像,在看到JMX能够对MBean进行管理的时候,我就觉得跟OSGI很像,OSGI管理的是Bundle,找了找资源,原来早就有人考虑过了:
http://teamojiao.iteye.com/blog/438334


顺便,在查资料的时候,发现一个东西,

if your question means, how to manage an OSGi runtime with JMX, you should have a look at MAEXO (http://code.google.com/p/maexo/). With MAEXO bundles up and running you will transparently get MBeans for a fair amount of services of the OSGi runtime as well
as MBeans for your own services and bundles. Just have a look at the screencast.



摘一些话:仅做参考



<网友回复>

一个大系统中,各内部模块系统之间的基于接口方式的互相调用和治理,使用jmx是最佳方案.

带来的好处是

1.面向接口,远程调用对于开发人员是透明的,模块在调用jmx接口时,与调用本地方法几乎相同.

2.可视化的治理界面, 通过 Jconsole等jmx客户端,可以实时监控系统,并且可实时调用方法进行某些操作.



典型应用场景: 



某聊天系统,一台服务器作为 在线用户列表服务器 A1, n台服务器为用户提供聊天业务处理 N1 ,N2,N3...,

一台服务器作为后台治理系统A2. 



系统治理员现在进行下面这样一个操作,察看某用户是否在线,找到该用户,发现其在线,则将该用户加入黑名单,并踢下线.



对应的jmx接口可以由以下几个: 

A1为A2提供查询在线用户jmx接口,加入黑名单接口,kickout接口,

A1为N1..等服务器提供以下接口: 注册业务服务器,添加在线用户.查找黑名单用户

N1...到N3为A1提供kickout接口.



因此在上面的踢下线操作,则由用户在A2的web界面发出,交由A1执行,A1记录黑名单之后,再找到用户所在业务服务器调用N1提供的接口让用户下线.





以上情形是在生产环境下的部署,而在开发工作,则可以将A1,A2,N...N3等功能合并在一个应用中调试. 由于使用的是jmx接口,在本地调试合并之后,可以直接调用应用内部接口方法.



这样借助jmx实现的应用模块的灵活组装与拆分,使得系统的可以根据负载需要,根据性能情况,灵活的拆分和整合部署分布式的应用.



替代方案,选择webservice,xmlrpc等,但是这些都需要手工编写或用工具生成大量的代码来辅助完成接口间的java对象序列化 。



经典jmx案例:

1.Jboss.使用jmx治理内部的各个service。

2. 基于java的开源网管软件 Hyperic HQ ,通过jmx与各被治理资源进行通讯和信息采集.







<网友回复>JMX是一个治理的框架。

当我们想使用JMX的时候,就要问,我们的系统当中有需要监控治理的资源或者对象吗?实事求是一点,我们不能为了想使用一个高端的技术,就歪曲系统的本来面目。

假如第一个问题是肯定的,接下来就是看这些资源是否有生命周期。

经典案例:jboss就是将所有可部署的组件作为资源来治理,这些组建都有其生命周期。这个理念甚至延伸到了其系统内部,将其内部的服务作为组件纳入到 JMX中来,成就了jboss基于jmx的微内核系统。





6 楼 happylouis 2015-09-10



5 楼 whmwg 2015-04-18



4 楼 luckywnj 2012-11-01
赞一个,jmx刚开始起步

3 楼 swanky_yao 2012-10-23
JMX性能怎么样?我目前的系统Server与Agent端的很多调用都是通过JMX 我怀疑这个对性能的影响有点大,就算是Hyperic HQ也只是很少部分用到了JMX

2 楼 碧海山城 2010-05-29

mercyblitz 写道
楼主你误解了,JMX主要的作用是监控,不过它可以调用方法。事实上,还是RMI的关系。

你说的WS相似的是RMI,不是JMX。

呵呵,对,JMX在RMI上又封装了一层,让我们实现它的规范,就可以实现“监控”。所以和WS相似的还是RMI,是不是可以说jmx一定程度上也是RMI的一种应用呢?

另外,其实JMX单单说是监控,其实我觉得不是很妥当,比如一个带点业务功能的方法:”获得注册用户“,这个方法也是可以被其他系统调用的,有点偏业务的意思,所以我说其实JMX也可以用于简单项目的开发,,,

1 楼 mercyblitz 2010-05-29
楼主你误解了,JMX主要的作用是监控,不过它可以调用方法。事实上,还是RMI的关系。

你说的WS相似的是RMI,不是JMX。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: