jboss数据库连接池的监控[转]

原文地址:http://www.evget.com/zh-CN/Info/ReadInfo.aspx?id=9298

 

一、 JMX简介

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

  Jboss的成功就在于采用了JMX,从零开始、模块化开发了Jboss服务器和容器,实现了模块化、嵌入式的技术架构。JMX作为集成中心 (总线),可以很方便的热插拔新的模块和组件。JMX服务可以通过HTTP、RMI、SNMP等多种协议进行访问,使其适合作为一个网络管理、监控平台的 技术架构。

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

  1. 工具层(Instrumentation Level)

  (a) MBeans(标准的,动态的,开放的和模型MBeans)

  (b) 通知模型:Notification、NotificationListener等类

  (c) MBean元数据类:Attribute、Opreator等类

  2. 代理层(Agent Level)

  (a) MBean Server

  (b) 代理服务。如jboss jmx-console下的HtmlAdaptorServer等。

   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。

 

三、监控jboss数据库连接池的实现

  import java.util.Iterator;

  import java.util.Properties;

  import java.util.Set;

  import javax.management.MBeanInfo;

  import javax.management.MBeanOperationInfo;

  import javax.management.MBeanParameterInfo;

  import javax.management.ObjectInstance;

  import javax.management.ObjectName;

  import javax.naming.InitialContext;

  import org.jboss.jmx.adaptor.rmi.RMIAdaptor;

  public class DataSourceManger {

    public static void main(String[] args) {

      // TODO 自动生成方法存根

      try {

        // Get RMIAdaptor Object

        Properties pro = new Properties();

        pro.setProperty("java.naming.factory.initial",

        "org.jnp.interfaces.NamingContextFactory");

        pro.setProperty("java.naming.provider.url", "jnp://localhost:1099");

        pro.setProperty("java.naming.factory.url.pkgs",

        "org.jboss.naming:org.jnp.interfaces");

        InitialContext ic = new InitialContext(pro);

        RMIAdaptor server = (RMIAdaptor) ic.lookup("jmx/rmi/RMIAdaptor");

        ObjectName name = new ObjectName("jboss.jca:name=jdbc/baosigpo,service=ManagedConnectionPool");

        ObjectName lname = new ObjectName("jboss.jca:name=jdbc/baosigpo,service=LocalTxCM");

        String AvailableConnectionCount = server.getAttribute(name,"AvailableConnectionCount").toString();

        System.out.println("===========avlide============"+ AvailableConnectionCount);

        String InUseConnectionCount = server.getAttribute(name,"InUseConnectionCount").toString();

        System.out.println("===========InUseConnectionCount============"+ InUseConnectionCount);

        String ConnectionCreatedCount = server.getAttribute(name,"ConnectionCreatedCount").toString();

        System.out.println("===========ConnectionCreatedCount============"+ ConnectionCreatedCount);

        String ConnectionDestroyedCount = server.getAttribute(name,"ConnectionDestroyedCount").toString();

        System.out.println("===========ConnectionDestroyedCount============"+ ConnectionDestroyedCount);

        ConnectionDestroyedCount = server.getAttribute(name,"ConnectionDestroyedCount").toString();

        System.out.println("===========ConnectionDestroyedCount============"+ ConnectionDestroyedCount);

        String[] argTypes = new String[0];

        int i = 0;

        i = Integer.parseInt(AvailableConnectionCount);

        Object opReturn = null;

        if (i < 1) {//监控可用连接数。

          StringBuffer sb = new StringBuffer();

          sb.append("oper before DataSource Pool info : \r\n");

          sb.append(" AvailableConnectionCount="+ AvailableConnectionCount);

          sb.append(" InUseConnectionCount=" + InUseConnectionCount);

          sb.append(" ConnectionCreatedCount="+ ConnectionCreatedCount);

          sb.append(" ConnectionDestroyedCount="+ ConnectionDestroyedCount);

          sb.append("\r\n");

          //opReturn = server.invoke(name, "flush", argTypes, argTypes);

          /*调用mbean的方法释放连接 begin 本实现方法对应jboss3.2.3

          对于jboss4以后的版本只需调用

          //opReturn = server.invoke(name, "flush", argTypes, argTypes);

          **/

          opReturn = server.invoke(name, "stop", argTypes, argTypes);

          opReturn = server.invoke(name, "start", argTypes, argTypes);

          opReturn = server.invoke(lname, "stop", argTypes, argTypes);

          opReturn = server.invoke(lname, "start", argTypes, argTypes);

          /*调用mbean的方法释放连接 end

          **/

          AvailableConnectionCount = server.getAttribute(name,"AvailableConnectionCount").toString();

          InUseConnectionCount = server.getAttribute(name,"InUseConnectionCount").toString();

          ConnectionCreatedCount = server.getAttribute(name,"ConnectionCreatedCount").toString();

          ConnectionDestroyedCount = server.getAttribute(name,"ConnectionDestroyedCount").toString();

          ConnectionDestroyedCount = server.getAttribute(name,"ConnectionDestroyedCount").toString();

          sb.append("oper afer DataSource Pool info :\r\n");

          sb.append(" AvailableConnectionCount="+ AvailableConnectionCount);

          sb.append(" InUseConnectionCount=" + InUseConnectionCount);

          sb.append(" ConnectionCreatedCount="+ ConnectionCreatedCount);

          sb.append(" ConnectionDestroyedCount="+ ConnectionDestroyedCount);

          //writeLog(sb.toString()); 操作日志信息

          System.out.println("===========op SUCCESS============");

        }

      } catch (Exception ex) {

        ex.printStackTrace();

      }

    }

  }

 

http://www.ibm.com/developerworks/cn/java/j-jtp10264/index.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值