>  기사  >  Java  >  SpringBoot를 사용하여 Hikari 연결 풀을 구현하고 JMX 모니터링을 구성하는 방법

SpringBoot를 사용하여 Hikari 연결 풀을 구현하고 JMX 모니터링을 구성하는 방법

王林
王林앞으로
2023-05-15 19:58:041677검색

Hikari는 Spring Boot의 기본 데이터베이스 연결 풀입니다. 다양한 상태 표시기를 Connection Pool 객체를 통해 직접 획득하는 C3P0과 달리 히카리는 JMX를 통해 이를 획득해야 한다. 데모는 다음과 같습니다. 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에 다음과 같은 문제가 언급되어 있습니다.

ObjectName poolName = new ObjectName("com.zaxxer.hikari:type=Pool (" + hikaridatasource.getPoolName() + ")");

오류가 발생할 수 있습니다

22:06:23.231 [main] DEBUG com.zaxxer.hikari.HikariConfig - 드라이버 클래스 com.mysql. 스레드 컨텍스트 클래스 로더 sun.misc.Launcher$AppClassLoader@73d16e93
Com.sun.proxy.$Proxy2.getIdleConnections(알 수 없는 소스) 스레드 "main" java.lang.reflect.UndeclaredThrowableException
의 예외에서 cj .jdbc.Driver가 발견되었습니다.
com.zte.hikariTest.HikariTest.main(HikariTest.java:32)
원인: javax.management.InstanceNotFoundException: com.zaxxer.hikari:type=Pool(foo)
com.sun.jmx.interceptor. DefaultMBeanServerInterceptor .getMBean(알 수 없는 소스)
at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getAttribute(알 수 없는 소스)
at com.sun.jmx.mbeanserver.JmxMBeanServer.getAttribute(알 수 없는 소스)
at com.sun.jmx.mbeanserver . MXBeanProxy$GetHandler.invoke(알 수 없는 소스)
at com.sun.jmx.mbeanserver.MXBeanProxy.invoke(알 수 없는 소스)
at javax.management.MBeanServerInvocationHandler.invoke(알 수 없는 소스)
... 2개 더

This 히카리 설정 매개변수는 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 ] 합계=[10]
2019-03-09 02:05:05.740 INFO com.zte.hikariTest.HikariTest.69 -HikariPoolState = 활성=[1] 유휴=[9] 대기=[0] 합계=[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]

위 내용은 SpringBoot를 사용하여 Hikari 연결 풀을 구현하고 JMX 모니터링을 구성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제