InstanceAlreadyExistsException:com.zaxxer.hikari:name = dataSource,type = HikariDataSource

9

我该如何解决这个问题?最好的选择是什么,怎样去做?

  1. 设置唯一的poolName
  2. 销毁之前的连接池

错误信息截图

org.apache.catalina.core.ApplicationContext.log Initializing Spring embedded WebApplicationContext
11-Aug-2018 16:05:53.863 SEVERE [Catalina-startStop-1] org.apache.catalina.core.ContainerBase.startInternal A child container failed during start
 java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[sss].StandardContext[]]
        at java.util.concurrent.FutureTask.report(FutureTask.java:122)
        at java.util.concurrent.FutureTask.get(FutureTask.java:192)
        at ..........
...............
......
Caused by: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[sss].StandardContext[]]
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:167)
        ... 6 more
Caused by: org.springframework.jmx.export.UnableToRegisterMBeanException: Unable to register MBean [HikariDataSource (HikariPool-2)] with key 'dataSource'; nested exception is javax.management.InstanceAlreadyExistsException: com.zaxxer.hikari:name=dataSource,type=HikariDataSource
        at org.springframework.jmx.export.MBeanExporter.registerBeanNameOrInstance(MBeanExporter.java:625)
        at 
..........................

org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5245)
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
        ... 6 more
Caused by: javax.management.InstanceAlreadyExistsException: com.zaxxer.hikari:name=dataSource,type=HikariDataSource
        at com.sun.jmx.mbeanserver.Repository.addMBean(Repository.java:437)
        at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerWithRepository(DefaultMBeanServerInterceptor.java:1898)
        at .................
............
        at com.sun.jmx.mbeanserver.JmxMBeanServer.registerMBean(JmxMBeanServer.java:522)`
1个回答

20

解决这个问题有两种方法。

i. 禁用jmx

ii. 设置default-domain和unique name(如果要启用jmx并且有多个相同应用的实例,则需要设置)

禁用jmx的方法:

application.yml:

spring:
  jmx:
    enabled: false

or application.properties:

spring.jmx.enabled= false

如果需要启用 JMX,请设置以下属性。

application.yml:

spring:
  jmx:
    default-domain: com.application.name
    unique-names: true

或者 application.properties:

spring.jmx.default-domain=com.application.name

只需使用 spring.jmx.default-domain 即可解决该异常。 - Vikcen

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接