JMX 学习

原创 2013年12月02日 13:29:56

       JMX(Java Management Extensions)是一个为应用程序植入管理功能的框架。JMX是一套标准的代理和服务,实际上,用户可以在任何Java应用程序中使用这些代理和服务实现管理。

  我们还是从JMX能给我们提供什么好处入手来理解吧。举一个应用实例:在一个系统中常常会有一些配置信息,比如服务的IP地址,端口号什么的,那么如何来写这些代码呢?
  1. 程序初哥一般是写死在程序里,到要改变时就去改程序,然后再编译发布;
  2. 程序熟手则一般把这些信息写在一个配置文件里(JAVA一般都是*.properties文件),到要改变时只要改配置文件,但还是重新启动系统,以便读取配置文件里的新值;
  3. 程序好手则会写一个段代码,把配置值缓存起来,系统在读值的时候,先看看配置文件有没有更动。如有更改则重读一遍,否则从缓存里读取值
  4. 程序高手则懂得取物为我所用,用JMX!把配置属性集中在一个类,然后写一个叫MBean的东东,再配置一下就轻松搞定了。而且JMX自动提供了一个WEB页面来给你来改变这些配置信息。

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

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

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

JMX构架中的各层及相关的组件

  1. 工具层(Instrumentation Level)
        (a) MBeans(标准的,动态的,开放的和模型MBeans)
        (b) 通知模型:Notification、NotificationListener等类
        (c) MBean元数据类:Attribute、Opreator等类
  2. 代理层(Agent Level)
        (a) MBean Server
        (b) 代理服务。如前一篇的HtmlAdaptorServer等。
HelloWorld实例

1、新建一个HelloMBean接口,如下:

public interface HelloMBean {
    public String getName();
    public void setName(String name);
    public void printHello();
    public void printHello(String whoName);
} 

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

2、实现HelloMBean接口,Hello是一个需要被管理的类(普通类)

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);
    }
}            

3、创建一个Agent类

package jmxtest;

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
        MBeanServer server = MBeanServerFactory.createMBeanServer();
        //创建MBean ObjectName
        ObjectName helloName = new ObjectName("MBeanTest:name=HelloWorld");
        //注册MBean
        Hello hello = new Hello();
        server.registerMBean(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.....");

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

说明:

      先创建了一个MBeanServer,用来做MBean的容器      将Hello这个类注入到MBeanServer中,注入需要创建一个ObjectName类      创建一个AdaptorServer,这个类将决定MBean的管理界面,这里用最普通的Html型界面。AdaptorServer其实也是一个MBean。      "MBeanTest:name=HelloWorld"的名字是有一定规则的,格式:“域名:name=MBean名称”,域名和MBean名称都可以任意取。

      在实际系统中我们可以把name变成决定数库链接池的变量,这样我就可以对系统的运行参数进行实现的监控和配置(管理)。访问浏览器 http://localhost:8082/,界面如下

点击 name=HelloWorld,查看MBean view

在MBean  Attribute中输入 yang,点击Apply

在MBean opteration中点击PrintHello

查看终端输出

点击Unregister按钮,移除MBean

返回Agent View页面,发现MBeanTest:name=HelloWorld已经不存在

HelloAgent:name=htmladapter,port=8082 View

尚在摸索中、、、


版权声明:本文为博主原创文章,未经博主允许不得转载。

【JMX学习】1、jmx入门

项目的web端和后端分开部署,用到JMX,使web端跟后端通信,当后端启动时加载一些文件,当web端修改时就会通知后端去更新,下面大概的学习下JMX,首先了解下JMX,然后做了一些小例子 一、j...
  • hy1945hy
  • hy1945hy
  • 2013年03月28日 13:28
  • 1429

JMX学习笔记(一)

1.JMX简介 JMX是Java Management Extension的缩写
  • java_huashan
  • java_huashan
  • 2014年06月19日 15:31
  • 1739

JMX学习笔记(四):Notifications

Notification J
  • java_huashan
  • java_huashan
  • 2014年06月24日 17:30
  • 1441

使用JMX监控Tomcat

1,什么是JMX        JMX是一种JAVA的正式规范,它主要目的是让程序有被管理的功能,那么怎么理解所谓的“被管理”呢?试想你开发了一个软件(如WEB网站),它是在24小时不间断运行的,那...
  • done58
  • done58
  • 2016年04月13日 15:45
  • 644

【JMX】2. JMX通知模型:Notification

复习 JMX构架中的各层及相关的组件 工具层(Instrumentation Level)     (a) MBeans(标准的,动态的,开放的和模型MBeans)     (b) 通知模型:No...
  • vking_wang
  • vking_wang
  • 2013年03月21日 14:16
  • 2070

jvirtualvm通过jmx远程连接jvm

jvirtualvm通过jmx远程连接jvm的配置和参数
  • wyh9459
  • wyh9459
  • 2017年03月19日 16:45
  • 377

为Web应用建立JMX管理系统(二)

四.创建MBean描述文件  在上面第三段代码中,我们可以看到,要将MBean注册到MBean Server中必须先创建MBeanInfo,MBean的setModelMBeanInfo()用来...
  • healxp
  • healxp
  • 2014年02月21日 10:58
  • 418

一、JMX官方指导文档 之 JMX概述

JMX概述 JMX(Java Management Exrensions)技术是标准Java平台的一部分。JMX技术从J2SE 5.0发布的时候添加到Java2平台。 JMX提供了一个标准的方法去管理...
  • jiaotuwoaini
  • jiaotuwoaini
  • 2017年05月01日 23:11
  • 367

如何使用JMX监控Kafka

使用kafka做消息队列中间件时,为了实时监控其性能时,免不了要使用jmx调取kafka broker的内部数据,不管是自己重新做一个kafka集群的监控系统,还是使用一些开源的产品,比如yahoo的...
  • u013256816
  • u013256816
  • 2016年12月08日 21:16
  • 7623

一句话介绍JMX——JMX基础

what?The Java Management Extensions (JMX) API is a standard API for management and monitoring of res...
  • lemon89
  • lemon89
  • 2015年05月09日 17:49
  • 1015
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JMX 学习
举报原因:
原因补充:

(最多只允许输入30个字)