> Java > java지도 시간 > 본문

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

王林
풀어 주다: 2023-05-15 19:58:04
앞으로
1688명이 탐색했습니다.

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으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!