如何在 JHIPSTER 生成的上下文中更改 HikariDataource bean 名称?

Posted

技术标签:

【中文标题】如何在 JHIPSTER 生成的上下文中更改 HikariDataource bean 名称?【英文标题】:How to change HikariDataource bean name in JHIPSTER generated context? 【发布时间】:2018-09-22 04:40:56 【问题描述】:

如果我尝试在单个 tomcat 中部署两个 JHIPSTER CONTEXT 的 WAR,则会抛出异常

那么如何在上下文中更改 HIkariCP bean 名称。

异常日志:

org.springframework.jmx.export.UnableToRegisterMBeanException:无法使用键“dataSource”注册 MBean [HikariDataSource (hikariDataSourceVirtuoSuite)];嵌套异常是 javax.management.InstanceAlreadyExistsException: com.zaxxer.hikari:name=dataSource,type=HikariDataSource 在 org.springframework.jmx.export.MBeanExporter.registerBeanNameOrInstance(MBeanExporter.java:628) 在 org.springframework.jmx.export.MBeanExporter.registerBeans(MBeanExporter.java:550) 在 org.springframework.jmx.export.MBeanExporter.afterSingletonsInstantiated(MBeanExporter.java:432) 在 org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:781) 在 org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:867) 在 org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:543) 在 org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:122) 在 org.springframework.boot.SpringApplication.refresh(SpringApplication.java:693) 在 org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:360) 在 org.springframework.boot.SpringApplication.run(SpringApplication.java:303) 在 org.springframework.boot.web.support.SpringBootServletInitializer.run(SpringBootServletInitializer.java:151) 在 org.springframework.boot.web.support.SpringBootServletInitializer.createRootApplicationContext(SpringBootServletInitializer.java:131) 在 org.springframework.boot.web.support.SpringBootServletInitializer.onStartup(SpringBootServletInitializer.java:86) 在 org.springframework.web.SpringServletContainerInitializer.onStartup(SpringServletContainerInitializer.java:169) 在 org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5622) 在 org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:145) 在 org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:1009) 在 org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:985) 在 org.apache.catalina.core.StandardHost.addChild(StandardHost.java:652) 在 org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:1127) 在 org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:2020) 在 java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 在 java.util.concurrent.FutureTask.run(FutureTask.java:266) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 在 java.lang.Thread.run(Thread.java:748) 引起:javax.management.InstanceAlreadyExistsException:com.zaxxer.hikari:name=dataSource,type=HikariDataSource 在 com.sun.jmx.mbeanserver.Repository.addMBean(Repository.java:437) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerWithRepository(DefaultMBeanServerInterceptor.java:1898) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerDynamicMBean(DefaultMBeanServerInterceptor.java:966) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerObject(DefaultMBeanServerInterceptor.java:900) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerMBean(DefaultMBeanServerInterceptor.java:324) 在 com.sun.jmx.mbeanserver.JmxMBeanServer.registerMBean(JmxMBeanServer.java:522) 在 org.springframework.jmx.support.MBeanRegistrationSupport.doRegister(MBeanRegistrationSupport.java:195) 在 org.springframework.jmx.export.MBeanExporter.registerBeanInstance(MBeanExporter.java:674) 在 org.springframework.jmx.export.MBeanExporter.registerBeanNameOrInstance(MBeanExporter.java:618) ... 省略了 25 个常用帧

2018-04-11 20:03:51.194 WARN 10440 --- [ost-startStop-1] ationConfigEmbeddedWebApplicationContext:在上下文关闭时从 LifecycleProcessor 抛出异常

java.lang.IllegalStateException:LifecycleProcessor 未初始化 - 在通过上下文调用生命周期方法之前调用“刷新”:org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@f46e3f7:启动日期 [Wed Apr 11 20:03:32 IST 2018];上下文层次的根 在 org.springframework.context.support.AbstractApplicationContext.getLifecycleProcessor(AbstractApplicationContext.java:427) 在 org.springframework.context.support.AbstractApplicationContext.doClose(AbstractApplicationContext.java:999) 在 org.springframework.context.support.AbstractApplicationContext.close(AbstractApplicationContext.java:958) 在 org.springframework.boot.SpringApplication.handleRunFailure(SpringApplication.java:750) 在 org.springframework.boot.SpringApplication.run(SpringApplication.java:314) 在 org.springframework.boot.web.support.SpringBootServletInitializer.run(SpringBootServletInitializer.java:151) 在 org.springframework.boot.web.support.SpringBootServletInitializer.createRootApplicationContext(SpringBootServletInitializer.java:131) 在 org.springframework.boot.web.support.SpringBootServletInitializer.onStartup(SpringBootServletInitializer.java:86) 在 org.springframework.web.SpringServletContainerInitializer.onStartup(SpringServletContainerInitializer.java:169) 在 org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5622) 在 org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:145) 在 org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:1009) 在 org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:985) 在 org.apache.catalina.core.StandardHost.addChild(StandardHost.java:652) 在 org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:1127) 在 org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:2020) 在 java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 在 java.util.concurrent.FutureTask.run(FutureTask.java:266) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 在 java.lang.Thread.run(Thread.java:748)

2018 年 4 月 11 日晚上 8:03:51 org.apache.catalina.core.ContainerBase addChildInternal 严重:ContainerBase.addChild:开始: org.apache.catalina.LifecycleException: 无法启动组件 [StandardEngine[Catalina].StandardHost[localhost].StandardContext[/VirtuoSuite]] 在 org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:162) 在 org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:1009) 在 org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:985) 在 org.apache.catalina.core.StandardHost.addChild(StandardHost.java:652) 在 org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:1127) 在 org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:2020) 在 java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 在 java.util.concurrent.FutureTask.run(FutureTask.java:266) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 在 java.lang.Thread.run(Thread.java:748) 原因:org.springframework.jmx.export.UnableToRegisterMBeanException:无法使用键“dataSource”注册 MBean [HikariDataSource (hikariDataSourceVirtuoSuite)];嵌套异常是 javax.management.InstanceAlreadyExistsException: com.zaxxer.hikari:name=dataSource,type=HikariDataSource 在 org.springframework.jmx.export.MBeanExporter.registerBeanNameOrInstance(MBeanExporter.java:628) 在 org.springframework.jmx.export.MBeanExporter.registerBeans(MBeanExporter.java:550) 在 org.springframework.jmx.export.MBeanExporter.afterSingletonsInstantiated(MBeanExporter.java:432) 在 org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:781) 在 org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:867) 在 org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:543) 在 org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:122) 在 org.springframework.boot.SpringApplication.refresh(SpringApplication.java:693) 在 org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:360) 在 org.springframework.boot.SpringApplication.run(SpringApplication.java:303) 在 org.springframework.boot.web.support.SpringBootServletInitializer.run(SpringBootServletInitializer.java:151) 在 org.springframework.boot.web.support.SpringBootServletInitializer.createRootApplicationContext(SpringBootServletInitializer.java:131) 在 org.springframework.boot.web.support.SpringBootServletInitializer.onStartup(SpringBootServletInitializer.java:86) 在 org.springframework.web.SpringServletContainerInitializer.onStartup(SpringServletContainerInitializer.java:169) 在 org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5622) 在 org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:145) ... 10 更多 引起:javax.management.InstanceAlreadyExistsException:com.zaxxer.hikari:name=dataSource,type=HikariDataSource 在 com.sun.jmx.mbeanserver.Repository.addMBean(Repository.java:437) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerWithRepository(DefaultMBeanServerInterceptor.java:1898) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerDynamicMBean(DefaultMBeanServerInterceptor.java:966) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerObject(DefaultMBeanServerInterceptor.java:900) 在 com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerMBean(DefaultMBeanServerInterceptor.java:324) 在 com.sun.jmx.mbeanserver.JmxMBeanServer.registerMBean(JmxMBeanServer.java:522) 在 org.springframework.jmx.support.MBeanRegistrationSupport.doRegister(MBeanRegistrationSupport.java:195) 在 org.springframework.jmx.export.MBeanExporter.registerBeanInstance(MBeanExporter.java:674) 在 org.springframework.jmx.export.MBeanExporter.registerBeanNameOrInstance(MBeanExporter.java:618) ... 25 更多

2018 年 4 月 11 日晚上 8:03:51 org.apache.catalina.startup.HostConfig deployWAR 严重:部署 Web 应用程序存档 C:\Program Files\Apache Software Foundation\apache-tomcat-7.0.81\webapps\VirtuoSuite.war 时出错 java.lang.IllegalStateException: ContainerBase.addChild: start: org.apache.catalina.LifecycleException: 无法启动组件 [StandardEngine[Catalina].StandardHost[localhost].StandardContext[/VirtuoSuite]] 在 org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:1013) 在 org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:985) 在 org.apache.catalina.core.StandardHost.addChild(StandardHost.java:652) 在 org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:1127) 在 org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:2020) 在 java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 在 java.util.concurrent.FutureTask.run(FutureTask.java:266) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 在 java.lang.Thread.run(Thread.java:748)

2018 年 4 月 11 日晚上 8:03:51 org.apache.catalina.startup.HostConfig deployWAR

【问题讨论】:

见github.com/jhipster/generator-jhipster/issues/874 这不是解决方案。将应用程序的spring.jmx.default-domain 设置为不同的值。 Tomcat 有一个 JMX 服务器,所有注册的东西都需要有一个唯一的名称。例如,只需根据应用程序名称分离核心。 【参考方案1】:

Java 管理扩展 (JMX) 管理 bean 的创建,因此如果我们更改 jmx 默认域名属性值,那么每个上下文都有不同的域名。所以在一个 tomcat 中没有两个 bean 具有相同的名称。

application.yml 文件中添加以下属性。

JMX default domain configuration in JHipster context

这里, 任何东西:这不会在 tomcat 的上下文中重复。主要是“应用程序名称”本身。

【讨论】:

以上是关于如何在 JHIPSTER 生成的上下文中更改 HikariDataource bean 名称?的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Jhipster+ React 应用程序中自定义 GUI

如何将上下文文件从 Wildfly 添加到 JHipster

更新 JHipster 生成器后如何更新 JHipster 项目?

jHipster:如何在 jdl 导入期间仅生成实体

如何使用 Jhipster 生成的代码为注销添加审核?

如何卸载生成器-jhipster