色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

Hikari連接池使用SpringBoot配置JMX監控實現

瀏覽:34日期:2023-02-26 14:13:26

Hikari是Spring Boot默認的數據庫連接池。區別于C3P0直接通過連接池對象獲取各項狀態指標,Hikari需要通過JMX來獲取。Demo如下,采用Spring Boot集成,定時采集連接狀態。

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() + ')');

可能會拋錯

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

這是因為Hikari設置參數同樣支持setHikariConfig和配置文件兩種配置方式,請選擇其中一種進行配置,而不是二者一起使用。并且請配置屬性如下,否則 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]

到此這篇關于Hikari連接池使用SpringBoot配置JMX監控的文章就介紹到這了,更多相關SpringBoot配置JMX監控內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
主站蜘蛛池模板: 中文字幕巨乱亚洲 | 精品视频久久 | 国内精品久久久久久久aa护士 | 亚洲国产精品免费在线观看 | 国产精品手机视频一区二区 | 一级啪啪片 | 精品国产一区二区三区免费 | 日本乱人伦片中文字幕三区 | 玖玖精品 | 99热久久国产精品这 | 韩日黄色| 一区二区三区在线 | 欧 | 欧美成人免费高清网站 | 激情丝袜美女视频二区 | 一区二区三区四区五区六区 | 欧美日韩国产亚洲综合不卡 | 狠狠色狠狠色狠狠五月ady | 成人国产精品免费视频 | 日本免费二区三区久久 | 久草热视频在线观看 | 精品久久久久久无码中文字幕 | 亚洲天堂视频在线观看 | 日韩成人小视频 | 免费国产成人高清在线观看不卡 | 免费毛片儿 | 欧美日韩综合高清一区二区 | 国产无套视频在线观看香蕉 | 一区国严二区亚洲三区 | 性久久久久久久久久 | 男人性天堂 | 欧美在线观看高清一二三区 | 亚洲高清视频在线观看 | 精品国产免费观看 | 欧美成人精品手机在线观看 | 曰本女同互慰高清在线观看 | 香港三澳门三日本三级 | 美女国产在线观看免费观看 | 精品国产中文一级毛片在线看 | 欧美一级毛片在线 | 欧美自拍在线 | 中文字幕一区二区视频 |