JR 精品文章 - 通过jmx监控jboss数据库连接池
AD: jr (at) javaresearch.org


首页 | 动态 | 文章 | FAQ  | 新闻 | 下载 | 代码 | 工作 | 调查 | 术语 | 站点 | 图书 | 论坛 | 帮助 | 全部  

TOP | 交流 | 软件 | 专栏 | 开源 | 译/著 | 源码 | API  | 推荐 | FTP  | 积分 | 统计 | 搜索 | Blog | 我们  
首页 » 研究文集 » 服务器及中间件 搜索标题相关文章 搜索标题相关文章    评论此文章 发表评论     开始监控此文章 开始监控   加入收藏夹  加入收藏夹
通过jmx监控jboss数据库连接池
yuchuan.zhan 原创   更新:2008-04-28 13:38:23  版本: 1.0   

通过jmx监控jboss数据库连接池
一、    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();
        }
    }
    
}
名词解释:
BlockingTimeoutMillis :抛出异常前最大的等待连接时间
IdleTimeoutMinutes :关闭连接前连接空闲的最大时间。即连接创建后由该项目规定的时间内未使用则释放连接,即系统创建的连接!
InUseConnectionCount 表示表示用户正在使用的连接!

ConnectionCount 这个项目代表在服务开启后,总共使用的连接数!
 ConnectionCreatedCount 表示jboss应用服务器自己创建的连接! 
ConnectionDestroyedCount 表示jboss释放的连接,包括用户释放的和系统自己释放的! IdleTimeoutMinutes 表示闲置释放时间,即连接创建后由该项目规定的时间内未使用则释放连接,即系统创建的连接!
 InUseConnectionCount 表示表示用户正在使用的连接! 
MaxConnectionsInUseCount 表示用户正在使用连接的峰值! 
其中InUseConnectionCount越少越好! ConnectionCreatedCount 越大越好! 这两项是关键!! AvailableConnectionCount为可用的连接数! 如果你的页面刷新AvailableConnectionCount的值没有变得话,说明你的页面创建的连接都关闭了,如果他的值减少了, 那么减少了多少,表示你有多少连接没有释放!!如果有可能的话,最好每个页面都测试一下,是否完全释放! 而 MaxConnectionsInUseCount 的值刚好和 AvailableConnectionCount相对应: 前者减少了多少,后者就增加多少!!! 而 MaxConnectionsInUseCount + AvailableConnectionCount = MaxSize 它们存在着这种关系!! 可以这样说InUseConnectionCount 就是未释放的连接数!!! 而MaxConnectionsInUseCount 则是未释放连接数的峰值

在具体应用中可以通过servlet 及定时器实现对连接池的实时监控。



版权声明   给作者写信
本篇文章对您是否有帮助?  投票:         投票结果:     7       0
作者其它文章: 作者全部文章
评论人:collectionset 发表时间: Wed Apr 30 14:38:59 CST 2008
ok this is good chapter

这个文章共有 1 条评论
主题: WebLogic Cluster的配置与应用程序发布的基础 上一篇文章
返回文章列表 返回〔服务器及中间件〕
下一篇文章 主题: 在JDK 1.5中实现真正面向对象形式的SQL语句


文字广告链接
        自主、快速定制基于JAVA的B/S业务系统          重量级企业在线自定义WEB报表平台
        Excel制表、零代码发布、打印、图表结合——快逸报表,免费、稳定、功能强大的java工具
        技术圈: 关于Java、dotNet、PHP、Ruby、奇客、Web2.0等更多资讯博客精选文章

关于 JR  |  版权声明  |  联系我们 

©2002-2006 JR 版权所有 沪ICP备05019622号