【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

相关文章

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

Python 中 requests 与 aiohttp 在实际项目中的选择策略详解

《Python中requests与aiohttp在实际项目中的选择策略详解》本文主要介绍了Python爬虫开发中常用的两个库requests和aiohttp的使用方法及其区别,通过实际项目案... 目录一、requests 库二、aiohttp 库三、requests 和 aiohttp 的比较四、requ

SpringBoot项目启动后自动加载系统配置的多种实现方式

《SpringBoot项目启动后自动加载系统配置的多种实现方式》:本文主要介绍SpringBoot项目启动后自动加载系统配置的多种实现方式,并通过代码示例讲解的非常详细,对大家的学习或工作有一定的... 目录1. 使用 CommandLineRunner实现方式:2. 使用 ApplicationRunne

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言