InstanceNotFoundException
問題:
啓動tomcat報錯:
ERROR [com.alibaba.druid.stat.DruidDataSourceStatManager] – unregister mbean error
javax.management.InstanceNotFoundException: com.alibaba.druid:type=DruidDataSourceStat
at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getMBean………
原因:在一臺服務器上啓動了兩個tomcat,兩個tomcat都是用druid。
解決方案:
修改Tomcat/bin 下的 catalina.sh:
增加此句代碼: JAVA_OPTS="$JAVA_OPTS -Ddruid.registerToSysProperty=true"
重啓tomcat
注意:確保catalina.sh有執行權限
InstanceAlreadyExistsException
Spring Boot的application.properties
文件也要加上:
spring.jmx.default-domain=applicationName
爲單個application設置相應的domain,將不同應用隔離。否則,Spring在創建datasource時,由於datasource的name是全局的,如果部署的多個應用有相同name的datasource,會報錯:
com.alibaba.druid.stat.DruidDataSourceStatManager.addDataSource(DruidDataSourceStatManager.java:154)] register mbean error
javax.management.InstanceAlreadyExistsException: com.alibaba.druid:type=DruidDataSource,id=Druid MySQL DB pool