【ITOO项目中遇到的问题】——为 MT_HOTEL_SERVICE 添加持久化单元服务失败

2024-08-26 00:58

本文主要是介绍【ITOO项目中遇到的问题】——为 MT_HOTEL_SERVICE 添加持久化单元服务失败,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、背景介绍


 项目框架采用的是EJB3.0,使用的JBossEap6.2服务器进行部署。


二、遇到的问题



为MT_HOTEL_SERVICE 添加持久化单元服务失败。   
    

三、错误日志


        

08:56:58,701 ERROR [org.jboss.msc.service.fail] (MSC service thread 1-1) MSC000001: Failed to start service jboss.deployment.subunit."itoo-exam-invigilate-ear.ear"."itoo-exam-invigilate-web.war".FIRST_MODULE_USE: org.jboss.msc.service.StartException in service jboss.deployment.subunit."itoo-exam-invigilate-ear.ear"."itoo-exam-invigilate-web.war".FIRST_MODULE_USE: JBAS018733: 处理 FIRST_MODULE_USE 的 subdeployment "itoo-exam-invigilate-web.war" of deployment "itoo-exam-invigilate-ear.ear" 阶段失败at org.jboss.as.server.deployment.DeploymentUnitPhaseService.start(DeploymentUnitPhaseService.java:127) [jboss-as-server-7.3.0.Final-redhat-14.jar:7.3.0.Final-redhat-14]at org.jboss.msc.service.ServiceControllerImpl$StartTask.startService(ServiceControllerImpl.java:1811) [jboss-msc-1.0.4.GA-redhat-1.jar:1.0.4.GA-redhat-1]at org.jboss.msc.service.ServiceControllerImpl$StartTask.run(ServiceControllerImpl.java:1746) [jboss-msc-1.0.4.GA-redhat-1.jar:1.0.4.GA-redhat-1]at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) [rt.jar:1.8.0_45]at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) [rt.jar:1.8.0_45]at java.lang.Thread.run(Thread.java:745) [rt.jar:1.8.0_45]
Caused by: org.jboss.as.server.deployment.DeploymentUnitProcessingException: JBAS011446: 为 MT_HOTEL_SERVICE 添加持久化单元服务失败at org.jboss.as.jpa.processor.PersistenceUnitServiceHandler.deployPersistenceUnit(PersistenceUnitServiceHandler.java:447)at org.jboss.as.jpa.processor.PersistenceUnitServiceHandler.addPuService(PersistenceUnitServiceHandler.java:275)at org.jboss.as.jpa.processor.PersistenceUnitServiceHandler.handleWarDeployment(PersistenceUnitServiceHandler.java:190)at org.jboss.as.jpa.processor.PersistenceUnitServiceHandler.deploy(PersistenceUnitServiceHandler.java:116)at org.jboss.as.jpa.processor.PersistenceBeginInstallProcessor.deploy(PersistenceBeginInstallProcessor.java:48)at org.jboss.as.server.deployment.DeploymentUnitPhaseService.start(DeploymentUnitPhaseService.java:120) [jboss-as-server-7.3.0.Final-redhat-14.jar:7.3.0.Final-redhat-14]... 5 more
Caused by: org.jboss.msc.service.DuplicateServiceException: Service jboss.persistenceunit."itoo-exam-invigilate-ear.ear/itoo-exam-invigilate-web.war#MT_HOTEL_SERVICE" is already registeredat org.jboss.msc.service.ServiceRegistrationImpl.setInstance(ServiceRegistrationImpl.java:154) [jboss-msc-1.0.4.GA-redhat-1.jar:1.0.4.GA-redhat-1]at org.jboss.msc.service.ServiceControllerImpl.startInstallation(ServiceControllerImpl.java:227) [jboss-msc-1.0.4.GA-redhat-1.jar:1.0.4.GA-redhat-1]at org.jboss.msc.service.ServiceContainerImpl.install(ServiceContainerImpl.java:561) [jboss-msc-1.0.4.GA-redhat-1.jar:1.0.4.GA-redhat-1]at org.jboss.msc.service.ServiceTargetImpl.install(ServiceTargetImpl.java:201) [jboss-msc-1.0.4.GA-redhat-1.jar:1.0.4.GA-redhat-1]at org.jboss.msc.service.ServiceControllerImpl$ChildServiceTarget.install(ServiceControllerImpl.java:2228) [jboss-msc-1.0.4.GA-redhat-1.jar:1.0.4.GA-redhat-1]at org.jboss.msc.service.ServiceTargetImpl.install(ServiceTargetImpl.java:201) [jboss-msc-1.0.4.GA-redhat-1.jar:1.0.4.GA-redhat-1]at org.jboss.msc.service.ServiceControllerImpl$ChildServiceTarget.install(ServiceControllerImpl.java:2228) [jboss-msc-1.0.4.GA-redhat-1.jar:1.0.4.GA-redhat-1]at org.jboss.msc.service.ServiceBuilderImpl.install(ServiceBuilderImpl.java:307) [jboss-msc-1.0.4.GA-redhat-1.jar:1.0.4.GA-redhat-1]at org.jboss.as.jpa.processor.PersistenceUnitServiceHandler.deployPersistenceUnit(PersistenceUnitServiceHandler.java:441)... 10 more

四、解决办法


(1)分析


关键词: 为 MT_HOTEL_SERVICE 添加持久化单元服务失败;#MT_HOTEL_SERVICE" is already registered。

(2)名词解释


      问:何为持久化单元?
      答:一个持久化单元(Persistence Unit)就是关于一组Entity类的命名配置。持久化单元是一个静态的概念。它具有唯一的名称,负责定义应用中的一组实体如何进行管理和持久性。

      持久化单元具有的属性:

            在该持久化性单元范围(作用域)内的实体类;

            为上述实体类提供持久性的持久性提供者(Persistence Provider)或库;

            上述实体类的数据源(Data Source);

            应用使用的事务类型(Transaction Type)。

            持久性单元能够被打包成war文件,EJB-Jar文件,EAR文件的一部分,或者直接打包成应用程序能够直接使用的JAR文件。

      问:何为MT_HOTEL_SERVICE?

      答:在我们的项目中,每一个系统的API的项目的META-INF目录下。都有一个persistence.xml。persistence.xml 是 JPA 的 配置文件。persistence.xml中配置了一个名为MT_HOTEL_SERVICE的持久化单元。

        项目中的persistence.xml文件内容:

<persistence-unit name="MT_HOTEL_SERVICE"transaction-type="JTA"><provider>org.eclipse.persistence.jpa.PersistenceProvider</provider><jta-data-source>java:jboss/datasources/CloudMysqlDS</jta-data-source><class>com.tgb.itoo.base.entity.BaseEntity</class><properties><!-- 修改第一次加载时间长的问题 --><property name="eclipselink.deploy-on-startup" value="true" /><!-- 修改为FINE后,控制台会打印出执行的sql语句,方便调试 --><property name="eclipselink.logging.level" value="FINE" />			<property name="eclipselink.jdbc.allow-native-sql-queries" value="true" /> <!-- 设置服务器类型 --><property name="eclipselink.target-server" value="JBoss" /><!-- logging --><!-- <property name="eclipselink.logging.level" value="SEVERE" /> --> <property name="eclipselink.weaving" value="static" /><property name="eclipselink.session.customizer" value="com.tgb.itoo.base.util.uuid.UUIDSequence" /><property name="eclipselink.show_sql" value="true" /></properties></persistence-unit>



      持久化单元的部署过程可以分为两个阶段进行:第一个阶段是解析persistence.xml文件,读取持久化单元的配置信息;第二个阶段是读取实体映射元数据,在内存中建立持久化单元所用数据库的模型,并根据需要初始化数据库对象。完成了这两步就开始创建实体管理器工厂。

(3)解决办法


      问题中出现的:#MT_HOTEL_SERVICE" is already registered。表示,已经注册了#MT_HOTEML_SERVICE,还要再去注册,我们查看了一下部署好的ear包里,在web的war里有两个不同版本的itoo-basic-api 的jar包,导致它需要解析两次。

     去掉我们不用的jar包版本即可部署成功。

五、总结


 问题虽然解决了,但是这些基本的知识还是要再去学习一下,现在能够解决问题,只是了解到了非常表面的一些东西,原理性的还不是很清楚,需要不断的去实践。


这篇关于【ITOO项目中遇到的问题】——为 MT_HOTEL_SERVICE 添加持久化单元服务失败的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1107096

相关文章

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

Docker镜像pull失败两种解决办法小结

《Docker镜像pull失败两种解决办法小结》有时候我们在拉取Docker镜像的过程中会遇到一些问题,:本文主要介绍Docker镜像pull失败两种解决办法的相关资料,文中通过代码介绍的非常详细... 目录docker 镜像 pull 失败解决办法1DrQwWCocker 镜像 pull 失败解决方法2总

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶

如何解决mysql出现Incorrect string value for column ‘表项‘ at row 1错误问题

《如何解决mysql出现Incorrectstringvalueforcolumn‘表项‘atrow1错误问题》:本文主要介绍如何解决mysql出现Incorrectstringv... 目录mysql出现Incorrect string value for column ‘表项‘ at row 1错误报错

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

如何解决Spring MVC中响应乱码问题

《如何解决SpringMVC中响应乱码问题》:本文主要介绍如何解决SpringMVC中响应乱码问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring MVC最新响应中乱码解决方式以前的解决办法这是比较通用的一种方法总结Spring MVC最新响应中乱码解

pip无法安装osgeo失败的问题解决

《pip无法安装osgeo失败的问题解决》本文主要介绍了pip无法安装osgeo失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 进入官方提供的扩展包下载网站寻找版本适配的whl文件注意:要选择cp(python版本)和你py