`

JMX架构的了解 (转)

    博客分类:
  • Java
阅读更多

JMX应该说是关于网络应用治理的的框架,假如你开发了一个比较复杂的系统,无疑你要提供这个系统的自身治理 系统,JMX更多应用是体现在Server 上,假如你要使用Java开发一个自己Server或复杂的应用系统,那么推荐你基于JMX架构来开发, JBoss 3.0 weblogic等就是基 于JMX开发的符合J2EE规范的服务器软件。 
  
  了解JMX可以使你深入了解J2EE服务器, 为什么我们平时说 "EJB"是 个比较"Weight"的方案选择,其中一个原因是J2EE服务器软件本身 也是你的系统中一部分,它作为你系统的容器,对你的系统有至关重要的作用,假 如无法直接介入 治理或“调教”它,那么无疑你的系统本身存在着隐含的危险, 现在,通过JMX,你现在可以深入到你J2EE容器内部的治理了。 (似乎 国内出现了第一个自己J2ee服务器,不知道那是不是基于JMX开发的?) 
  
  J2EE并不能概括所有的应用领域,比如对速度和性 能要求极高的游戏或股票行情等系统就需要自己直接来开发Server, 假如是能够基于JMX开发,那么可以说就大大提高编写治理程序的效率,可以将你的 模块变成JMX的MBean,可以通过Agent在程序内部或者通过 WEB治理页面对你的MBean模块进行初始化 重启 以及参数设置。
  
  JMX的好处还有:可以方便整合连接现有的Java技术,如JNDI JDBC JTS及其它。非凡是能够使用Jini的查询 发现机制以及协议,我们知道,Jini提供了一种服务的查询和发现机制,这些services都可以通过JMX 来实现治理。
  
  现在我们开始JMX的了解:
  
  1.到java.sun.com首页的JMX页面,下载JMX的规定说明和Samples程序。
  2.按照JMX的说明进行一次Tutorial,了解如何加入 删除 配置一个MBean,Tutorial中是以SimpleMBean为例,那么我们能否建立一个自己的MBean?
  
  我们来做一个Hello 的MBean,这里有一个小要害点,你的class取名有个规则, 需要以MBean为结尾,如这里我们取名为HelloMbean:

public interface HelloMBean {
  
  // management attributes
  public String getName();
  public void setName(String name);
  
  // management operations
  public void print();
  
  }
 

  
  在这个Class里,有一个隐含attributes: name, 提供了set和get的方法,同时有一个操作方法print():
  
  再定义一个concrete类:
  

public class Hello implements HelloMBean {
  
  private String name = "";
  
  public String getName() {
  return name;
  }
  
  public void setName(String name) {
  this.name = name;
  }
  
  public void print() {
  System.out.println("Hello, " + name + "!!" );
  }
  }
 

  
  
  这样一个简单的MBean就做好了,我们可以通过admin界面加入这个Hello,
  
  再按 Tutorial启动BaseAgent,在Agent Administration中参考Simple填入:

Domain: Standard_Hello_MBeans
  
Keys : name=Hello,number=1
  
Java Class: Hello
 

  
  将出现Create SUCcessful信息。进入MBean View 给Name赋值,点按Apply ,然后再按print,这是你的Hello中的方法,在控制台你会看到输出。
  
  是不是很惊异Hello中的 attributes 和operations能被动态的访问和控制? 已经隐约感到JMX的架构原理了吧?
  
  下面再深入明确一些概念:
   上面HelloMBean资源是通过admin这样的HTTP WEB界面治理,这种治理资源方式是属于JMX的Distributed服务 层, JMX 通过Distributed层能够部署和治理MBean资源。就象上面的例子,是通过HtmlAdaptor提供的HTTP WEB界面来 方面的维护治理HelloMBean.
  
  那么我们能否在程序中自动治理和部署我的MBean?当然可以,这是通过Agent层来完成,现在我们已经有了这个层次,MBean所在的资源层,
  最外面的Distributed服务层,Distributed服务层是通过Agent层来访问MBean资源的,看看下面来自Sun公司JMX规定的架构图:
  

点击查看大图


  从图中看出,Agent Level(Agent层)包括MBean Server和Agent Services,那么我们来做一个上面例子HelloMBean的Agent:
  

// CREATE the MBeanServer
  //
  System.out.println(" CREATE the MBeanServer.");
  MBeanServer server = MBeanServerFactory.createMBeanServer();
  
  // CREATE Registe HelloMBean
  //
  System.out.println(" CREATE, REGISTER a new Hello Standard_MBean:");
  HelloMBean helloMBean = new Hello();
  
  ObjectName hello_name = null;
  try {
  hello_name = new ObjectName("Standard_Hello_MBeans:name=Hello,number=1");
  System.out.println(" OBJECT NAME = " + hello_name);
  
  //将HelloMBean注册到MBeanServer中去
  server.registerMBean(helloMBean, hello_name);
  }
  catch (Exception e) {
  e.printStackTrace();
  return;
  }
 

  
  向MBeanServer注册后,以后JMX就知道有了这个HelloMBean资源。
  
   治理一个agent的MBean资源或使用它提供的服务必须通过一个protocol adaptor 或者connector,adaptor 或者 connector属于Distributed layer level(Distributed服务层),我们上面例子中通过HTTP WEB界面治理 HelloMBean就是浏览器通过HtmlAdaptor这个adaptor来实现的。
  
  通过本篇文章,你应该大体了解了JMX的架构和一些原理和应用,再深入可以研究SUN的JMX Specification.

分享到:
评论

相关推荐

    JBoss JMX实现架构

    JBoss JMX实现架构 JBoss JMX实现架构

    JMX实战 JMX开发

    书中不仅有对于基础知识的介绍,还有对于JMX开发中重大的体系架构问题的深入探讨,总结了大量JMX开发中的设计模式,并讨论了框架、安全性与性能等等。书中提供了几个典型的例子,兼顾各种开发平台,这些例子的代码...

    jmx入门

    为什么JMX那么受欢迎,JMX到底有那些优势只得人们去学习和理解,本文从JMX的基本架构、hellowold jmx以及spring对JMX的支持讲起,希望大家能通过本文对JMX有个基础的认识,并能通过本文为今后学习JMX打个基础

    JMX1.4规范中文版

    这篇文档是对JMX 的一个介绍,给出了定JMX 设备层,...它不是编程手册或者教程,而是希望读者可以对JMX 架构、设计模式和编程接口有一定程 度的理解。 完整的JMX 规范是由本书和API 文档组成的,它们定义了所有编程对象

    jmx一步步来 jmx快速上手指南

    jmx快速上手 jmx快速上手 jmx快速上手 jmx快速上手

    Fiddler导出jmx文件

    Fiddler导出jmx文件,解决Fiddler导出文件中 没有jmx文件选项,各个版本fiddler都适用

    JMX应用技术架构系统(包括具体开发说明)

    JMX应用技术架构系统(包括具体开发说明),详细介绍了JMX的应用场景以及MX4J在分布式应用监控方面的应用开发方法.

    jmx介绍和使用

    jmx的简单介绍和使用,包含一些简单的代码示例,看完基本能了解jmx并使用。

    jmx-jvm配置

    jmx配置

    jmx 实例 rmi mbean

    jmx 实例 rmi mbean,采用rmi方式进行jmx的mbean管理,通过这个实例能够了解jmx的应用

    亲测可用 com.sun.jmx. jmxri-1.2.1.jar

    Description Resource Path Location Type Missing artifact com.sun.jmx:jmxri:jar:1.2.1 pom.xml /eshop-storm line 2 Maven Dependency Problem

    JMX小例子以及介绍

    JMX小例子以及介绍 JMX小例子以及介绍 JMX小例子以及介绍

    Jmx实例demo下载

    java实现Jmx实例,jmxdemo项目源码下载

    jmx监控tomcat测试包

    catalina-jmx-remote.jar放到tomcat/lib目录下 如果是windows版本,编辑TOMCAT_HOME/bin/catalina.bat,在开头加入下面几行: set CATALINA_OPTS=%CATALINA_OPTS% -Djava.rmi.server.hostname=JMX_HOST set CATALINA...

    JMX与JMS的概念

    JMX与JMS的概念

    JMX一步一步来,快速学会开发JMX应用

    JMX一步一步来,从最基本的应用开始入手,快速应用开发。

    JMX 在GlassFish中的应用

    jmx和jmx在glassfish中的应用

    JMX学习,开发文档

    有关JMX学习的一些文档,对初学JMX的朋友有帮助.

Global site tag (gtag.js) - Google Analytics