Hikari連接池使用SpringBoot配置JMX監(jiān)控實(shí)現(xiàn)
Hikari是Spring Boot默認(rèn)的數(shù)據(jù)庫連接池。區(qū)別于C3P0直接通過連接池對(duì)象獲取各項(xiàng)狀態(tài)指標(biāo),Hikari需要通過JMX來獲取。Demo如下,采用Spring Boot集成,定時(shí)采集連接狀態(tài)。
public static void main(String[] args) throws SQLException, MalformedObjectNameException, InterruptedException { SpringApplication.run(HikariTest.class, args); HikariDataSource hikaridatasource = new HikariDataSource(); hikaridatasource.setJdbcUrl('jdbc:mysql://localhost:3306?serverTimezone=GMT'); hikaridatasource.setUsername('root'); hikaridatasource.setPassword(''); hikaridatasource.setDriverClassName('com.mysql.cj.jdbc.Driver'); hikaridatasource.setRegisterMbeans(true); hikaridatasource.setPoolName('HikariConnectionPool'); MBeanServer mBeanServer = ManagementFactory.getPlatformMBeanServer(); ObjectName poolName = new ObjectName('com.zaxxer.hikari:type=Pool (' + hikaridatasource.getPoolName() + ')'); poolProxy = JMX.newMXBeanProxy(mBeanServer, poolName, HikariPoolMXBean.class); Connection conn = hikaridatasource.getConnection(); Statement sm = conn.createStatement(); ResultSet rs = null; for (int i = 0; i < 999999999; i++) { rs = sm.executeQuery('select name from test.t1'); } rs.close(); sm.close(); conn.close(); hikaridatasource.close();}@Scheduled(fixedRate = 1000)public void HikariMonitor() { if(poolProxy == null) { log.info('Hikari not initialized,please wait...'); }else { log.info('HikariPoolState = ' + 'Active=[' + String.valueOf(poolProxy.getActiveConnections() + '] ' + 'Idle=[' + String.valueOf(poolProxy.getIdleConnections() + '] ' + 'Wait=['+poolProxy.getThreadsAwaitingConnection()+'] ' + 'Total=['+poolProxy.getTotalConnections()+']'))); } }
另外,在github有提到這樣的issue:
ObjectName poolName = new ObjectName('com.zaxxer.hikari:type=Pool (' + hikaridatasource.getPoolName() + ')');
可能會(huì)拋錯(cuò)
22:06:23.231 [main] DEBUG com.zaxxer.hikari.HikariConfig - Driver class com.mysql.cj.jdbc.Driver found in Thread context class loader sun.misc.Launcher$AppClassLoader@73d16e93Exception in thread 'main' java.lang.reflect.UndeclaredThrowableException at com.sun.proxy.$Proxy2.getIdleConnections(Unknown Source) at com.zte.hikariTest.HikariTest.main(HikariTest.java:32)Caused by: javax.management.InstanceNotFoundException: com.zaxxer.hikari:type=Pool (foo) at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getMBean(Unknown Source) at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getAttribute(Unknown Source) at com.sun.jmx.mbeanserver.JmxMBeanServer.getAttribute(Unknown Source) at com.sun.jmx.mbeanserver.MXBeanProxy$GetHandler.invoke(Unknown Source) at com.sun.jmx.mbeanserver.MXBeanProxy.invoke(Unknown Source) at javax.management.MBeanServerInvocationHandler.invoke(Unknown Source) ... 2 more
這是因?yàn)镠ikari設(shè)置參數(shù)同樣支持setHikariConfig和配置文件兩種配置方式,請(qǐng)選擇其中一種進(jìn)行配置,而不是二者一起使用。并且請(qǐng)配置屬性如下,否則 JMX 無法生效。
hikaridatasource.setRegisterMbeans(true);
代碼效果如下所示
2019-03-09 02:05:04.738 INFO com.zte.hikariTest.HikariTest.69 -HikariPoolState = Active=[1] Idle=[9] Wait=[0] Total=[10]2019-03-09 02:05:05.740 INFO com.zte.hikariTest.HikariTest.69 -HikariPoolState = Active=[1] Idle=[9] Wait=[0] Total=[10]2019-03-09 02:05:06.732 INFO com.zte.hikariTest.HikariTest.69 -HikariPoolState = Active=[1] Idle=[9] Wait=[0] Total=[10]2019-03-09 02:05:07.738 INFO com.zte.hikariTest.HikariTest.69 -HikariPoolState = Active=[1] Idle=[9] Wait=[0] Total=[10]
到此這篇關(guān)于Hikari連接池使用SpringBoot配置JMX監(jiān)控的文章就介紹到這了,更多相關(guān)SpringBoot配置JMX監(jiān)控內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. Java commons-httpclient如果實(shí)現(xiàn)get及post請(qǐng)求2. 一文帶你徹底理解Java序列化和反序列化3. JS中6個(gè)對(duì)象數(shù)組去重的方法4. Python基于requests庫爬取網(wǎng)站信息5. vscode運(yùn)行php報(bào)錯(cuò)php?not?found解決辦法6. python中文本字符處理的簡(jiǎn)單方法記錄7. PHP laravel實(shí)現(xiàn)導(dǎo)出PDF功能8. Python使用Selenium自動(dòng)進(jìn)行百度搜索的實(shí)現(xiàn)9. PHP利用curl發(fā)送HTTP請(qǐng)求的實(shí)例代碼10. 資深程序員:給Python軟件開發(fā)測(cè)試的25個(gè)忠告!

網(wǎng)公網(wǎng)安備