原文地址: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
分享到:
相关推荐
数据库连接池原理是现代软件开发中提升性能和资源管理的关键技术之一,特别是在Web应用系统中。传统的JDBC访问数据库的方式存在资源浪费和效率低下的问题,每次数据访问都需要建立、打开、使用和关闭数据库连接,这...
常见的J2EE服务器如JBOSS和WebLogic都内置了数据库连接池的支持,为开发者提供了便利。通过合理配置和使用连接池,可以显著提升JSP应用的性能,优化资源管理,保证系统的稳定性和可靠性。因此,理解和应用数据库连接...
总的来说,选择合适的数据库连接池需要考虑性能、稳定性、监控需求以及项目规模等因素。在实际开发中,理解并合理配置这些连接池的参数,能够有效地提升系统的运行效率,确保数据库操作的稳定性和可靠性。
Druid是目前最好的数据库连接池,在功能、性能、扩展性方面,都超过其他数据库连接池,包括DBCP、C3P0、BoneCP、Proxool、JBoss DataSource。Druid已经在阿里巴巴部署了超过600个应用,经过一年多生产环境大规模部署...
通过统一的图形化管理控制台,您可以管理和监控网络、操作系统、数据库等基础设施服务,也可以管理和监控Java虚拟机、JBoss Web、连接池等中间件,还可以通过自定义的JMX MBean管理和监控您的业务应用。通过对配置...
- 使用连接池监控工具,如HikariCP自带的健康检查,监控连接池的状态和性能。 - 定期进行连接池的维护和优化,确保系统的稳定性和高可用性。 - 在多线程环境下,确保正确管理和关闭数据库连接,避免出现死锁或...
2. **应用服务器连接池配置**:当前的Jboss连接池设置过高,允许的最大连接数可能超过实际需求,导致数据库在面对突发流量时压力剧增。建议根据实际业务需求调整连接池的最小和最大值,避免无谓的资源浪费。 3. **...
四、Jboss数据库连接池优化: JBOSS使用了内置的连接池,如HornetQ或 datasources。优化连接池配置可以提高数据库操作的效率。这可能涉及到调整以下参数: 1. `min-pool-size`:最小连接数,保证低负载时的数据库...
#### 四、JBoss数据库连接池优化 数据库连接池是提高数据库访问性能的重要手段。通过合理配置连接池,可以显著提升系统的吞吐量和响应速度。 **优化要点:** 1. **连接池大小:** - 调整`min-pool-size`参数以...
Proxool是一个开源的轻量级Java数据库连接池实现,其主要目标是替代常见的数据库连接池解决方案,如C3P0或DBCP,并且提供了更加灵活和易于配置的特性。在实际应用中,合理配置Proxool可以显著提高系统的性能和稳定性...
Druid是一个综合了监控诊断、性能优化、扩展性等诸多特性的数据库连接池。它的主要功能包括: 1. **连接池管理**:Druid能够有效地管理数据库连接,避免频繁创建和关闭连接带来的性能损失,提供线程安全的数据库...
- **数据库服务器**:安装MySQL数据库服务器,并配置好相应的数据源和连接池设置。 3. **应用程序修改**: - **EJB实体类**:虽然在示例中,实体EJB类(如CatalogBean.java)不需要修改,但在实际迁移过程中,...
4. **连接池**:调整数据库连接池大小,避免资源浪费和连接泄露。 5. **部署优化**:避免不必要的服务和模块,精简部署包。 6. **日志级别**:降低日志级别以减少I/O开销。 7. **网络配置**:优化网络连接,如调整...
【Druid数据库分析工具】是Java开发中的一款高效且功能丰富的数据库连接池,它在功能、性能和扩展性上超越了DBCП、C3P0、Proxool、JBoss DataSource等其他数据库连接池。Druid经过阿里巴巴大量应用的部署验证,具有...
3. **连接池优化**:数据库连接池的设置直接影响到数据访问性能。合理设定连接池的最大连接数、最小连接数、超时时间等,可以减少数据库连接创建和销毁的开销,提高数据库操作效率。 4. **部署配置优化**:包括修改...
这些组件优化了数据库连接池,确保了高并发场景下的性能。 7. **集群与高可用性**: 支持集群部署是EAP 7.2.0的一大特点,它可以创建多个服务器实例形成集群,提供负载均衡和故障转移,从而实现高可用性。 8. **...
总结,JBoss 页面调度是一个复杂而关键的领域,涉及内容广泛,包括分发策略、数据库连接池管理、工具集成、配置优化、缓存策略、安全性和集群部署等多个方面。理解并掌握这些知识点,有助于构建高效、稳定的 Java EE...
在性能调优方面,学习如何监控和调整内存设置、线程池大小、数据库连接池等,可以帮助提升服务器的响应速度和稳定性。JBoss提供了丰富的监控工具,如JMX(Java Management Extensions)和Web管理控制台,使管理员...
- 根据应用需求调整数据源的连接池参数,如最大连接数、最小连接数、空闲超时时间等,以优化性能和资源利用。 以上就是配置JBoss连接Oracle数据源的基本步骤。注意,实际操作中可能还需要根据具体的JBoss版本和...
2. 性能调优:可以通过调整JVM参数、数据库连接池大小、内存分配等进行性能优化。 九、JBOSS与Java EE JBOSS作为Java EE的实现,支持Java EE的各种规范,如Servlet、JSP、EJB、JMS、JPA等,使得开发者可以轻松构建...