没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
转帖|其它|编辑:郝浩|2009-01-15 14:24:33.000|阅读 2123 次
概述:JMX(Java Management Extensions, Java管理扩展)是一个为应用程序植入管理功能的框架。JMX是一套标准的代理和服务,实际上,用户可以在任何Java应用程序中使用这些代理和服务实现管理。
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
文章关键字:|jboss|数据库|连接池|监控|JMX|框架|服务器|
一、 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。[SPAN]
三、监控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();
}
}
}
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
文章转载自:IT专家网面对“数字中国”建设和中国制造2025战略实施的机遇期,中车信息公司紧跟时代的步伐,以“集约化、专业化、标准化、精益化、一体化、平台化”为工作目标,大力推进信息服务、工业软件等核心产品及业务的发展。在慧都3D解决方案的实施下,清软英泰建成了多模型来源的综合轻量化显示平台、实现文件不失真的百倍压缩比、针对模型中的大模型文件,在展示平台上进行流畅展示,提升工作效率,优化了使用体验。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号