使用 JMX 监控 DBCP2 连接池

Posted

技术标签:

【中文标题】使用 JMX 监控 DBCP2 连接池【英文标题】:Monitoring DBCP2 connection pool with JMX 【发布时间】:2016-05-02 01:45:30 【问题描述】:

我从 DBCP2 文档中了解到,这个新版本支持对连接池进行 JMX 监控,但我找不到任何显示实际用法的示例。

我有一个简单的基于 JDBC 的 java 应用程序,它使用 dbcp2 创建一个连接池,供一个简单的查询服务使用,我想通过另一个工具(如使用 JMX 的 VisualVM)来监控这些连接。 DBCP2 的BasicDataSource 有类似setJmxName() 的方法 我没有看到任何用法,也不知道如何使用它。

如果有人对 JDBC 不熟悉,可以阅读一下here。

对此的任何帮助将不胜感激。 谢谢!

【问题讨论】:

改进了问题格式,使其更易于理解。为其他人添加了一些指向 JDBC 文档的资源,以便更轻松地跟进该主题的重点。 我在生产环境中使用 DBCP2 时遇到了很多问题,因为它有大量线程,我决定使用运行良好的 C3P0,而且它有一个非常好的 JMX 实现。 【参考方案1】:

我也没有找到任何文档,但我通过挖掘源代码发现了一些东西。

您只需要像往常一样创建一个BasicDataSourceBasicManagedDataSource 对象,然后调用setJmxName() 方法。然后,DataSource 将在您调用 getConnection() 方法时向平台的 MBean 服务器注册自己,并在您调用 close() 方法时取消注册自己。


将 JMX 名称设置为 "org.apache.dbcp:DataSource=mydbname" 有效,Apache 用于单元测试的示例可以是 found here。

【讨论】:

这里描述了对象名称语法:oracle.com/us/technologies/java/best-practices-jsp-136021.html

以上是关于使用 JMX 监控 DBCP2 连接池的主要内容,如果未能解决你的问题,请参考以下文章

dbcp2连接池获取数据库连接Connection

2019.4.1 数据库连接池

ssh+连接池配置出现的问题

连接池

DBCP2配置详细说明(中文翻译)

DBCP2的使用例子和源码详解(包括JNDI和JTA支持的使用)