我一直在尝试重构Java项目,将子模块移动到部署到我们内部Maven存储库(archiva)的单独项目中。

子模块中的类如下:

org.example.srv.DomainUser
org.example.srv.DomainUserBean //entity manager
org.example.srv.UserGroup
org.example.srv.UserGroupBean //entity manager

当将源文件复制到主后端服务器项目内的适当package文件夹中时,它工作正常,但是当我们从后端服务器项目中删除源文件并将相同的代码作为maven依赖项放入时,出现以下错误在尝试访问数据库时:
org.hibernate.UnknownEntityTypeException: Unable to locate persister: org.example.srv.DomainUser

后端服务器项目的持久性XML:
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">
<persistence-unit name="loginserver">
    <properties>
        <property name="javax.persistence.schema-generation.database.action" value="drop-and-create"/>
    </properties>
</persistence-unit>
</persistence>

我只能想象这与项目分离时的bean发现有关,但是我真的很困惑,以最小的配置开销来分离这些项目将是很棒的。

主服务器项目pom.xml:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>org.example.srv</groupId>
    <artifactId>loginserver</artifactId>
    <version>0.0.2-SNAPSHOT</version>
    <packaging>war</packaging>
    <dependencies>
        <dependency>
            <groupId>javax</groupId>
            <artifactId>javaee-api</artifactId>
            <version>7.0</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>com.unboundid</groupId>
            <artifactId>unboundid-ldapsdk</artifactId>
            <version>3.2.0</version>
        </dependency>
        <dependency>
            <groupId>org.example</groupId>
            <artifactId>authobjects</artifactId>
            <version>1.0.0</version>
        </dependency>
    </dependencies>
    <build>
        <finalName>loginserver</finalName>
    </build>
    <properties>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
        <failOnMissingWebXml>false</failOnMissingWebXml>
    </properties>
</project>

Auth Objects pom.xml(此项目还包含类的ORM代码,包括JPQL语句构建器等):
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <properties>
        <pj.gid>org.example</pj.gid>
        <pj.aid>authobjects</pj.aid>
        <pj.ver>1.0.2-SNAPSHOT</pj.ver>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
    </properties>

    <groupId>${pj.gid}</groupId>
    <artifactId>${pj.aid}</artifactId>
    <version>${pj.ver}</version>

    <dependencies>
        <dependency>
            <groupId>javax</groupId>
            <artifactId>javaee-api</artifactId>
            <version>7.0</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>ent.tnp.utils</groupId>
            <artifactId>genericentityejb</artifactId>
            <version>1.0.0</version>
        </dependency>
    </dependencies>

    <build>
        <extensions>
            <extension>
                <groupId>org.apache.maven.wagon</groupId>
                <artifactId>wagon-webdav</artifactId>
                <version>1.0-beta-2</version>
            </extension>
        </extensions>
    </build>

    <distributionManagement>
        <repository>
            <id>internal</id>
            <url>http://archiva.tnp.in/repository/internal/</url>
        </repository>
        <snapshotRepository>
            <id>snapshots</id>
            <url>http://archiva.tnp.in/repository/snapshots/</url>
        </snapshotRepository>
    </distributionManagement>

    <repositories>
        <repository>
            <id>internal</id>
            <name>Archiva Managed Internal Repository</name>
            <url>http://archiva.tnp.in/repository/internal/</url>
            <releases>
                <enabled>true</enabled>
            </releases>
            <snapshots>
                <enabled>false</enabled>
            </snapshots>
        </repository>
        <repository>
            <id>snapshots</id>
            <name>Archiva Managed Snapshot Repository</name>
            <url>http://archiva.tnp.in/repository/snapshots/</url>
            <releases>
                <enabled>false</enabled>
            </releases>
            <snapshots>
                <enabled>true</enabled>
            </snapshots>
        </repository>
    </repositories>
    <pluginRepositories>
        <pluginRepository>
            <id>internal</id>
            <name>Archiva Managed Internal Repository</name>
            <url>http://archiva.tnp.in/repository/internal/</url>
            <releases>
                <enabled>true</enabled>
            </releases>
            <snapshots>
                <enabled>false</enabled>
            </snapshots>
        </pluginRepository>
        <pluginRepository>
            <id>snapshots</id>
            <name>Archiva Managed Snapshot Repository</name>
            <url>http://archiva.tnp.in/repository/snapshots/</url>
            <releases>
                <enabled>false</enabled>
            </releases>
            <snapshots>
                <enabled>true</enabled>
            </snapshots>
        </pluginRepository>
    </pluginRepositories>

</project>

澄清:genericentityejb是一个抽象类,旨在组成JPQL查询并管理JPA实体的数据库查询。 authobjects项目为它包含的每个实体扩展了一次,以便为每个实体提供持久性。

最佳答案

从我看来,至少涉及 4个模块:

  • org.example.srv:loginserver:0.0.2-SNAPSHOT
  • org.example:authobjects:1.0.0
  • org.example:authobjects:1.0.2-SNAPSHOT
  • ent.tnp.utils:genericentityejb:1.0.0

  • 我注意到一些可能的严重性:
  • loginserver不取决于authobjects,而是取决于genericentityejb(它们是两个不相关的示例项目吗?)。
  • loginserver不取决于authobjects:1.0.2-SNAPSHOT,而是取决于authobjects:1.0.0
  • loginserver没有声明任何存储库(都不是父POM),因此,除非您在全局genericentityejb中声明了存储库,否则settings.xml总是从本地计算机存储库中解析的。
  • 我不确定对authobjects项目groupId,artifactId和version使用属性是个好主意。也许它不相关,但是我会避免这样的声明。

  • 话虽如此,我在我的项目中使用了类似的结构,将其部署到Wildfly 10.1,Hibernate正确地发现了所有依赖项中的所有实体。

    因此,我尝试进行一次干净的回合。
    我将忽略authobjects,因为它没有被引用,并且我认为必需的实体类在genericentityejb中:
  • genericentityejb POM版本修改为1.0.1-SNAPSHOT
  • genericentityejb文件夹中的
  • :mvn clean install
  • authobjects POM版本修改为1.0.3-SNAPSHOT,将依赖genericentityejb修改为1.0.1-SNAPSHOT
  • authobjects文件夹中的
  • :mvn clean install
  • loginserver依赖性authobjects修改为0.0.3-SNAPSHOT,并将authobjects依赖性修改为1.0.3-SNAPSHOT
  • loginserver文件夹中的
  • :mvn dependency:analyze检查是否使用了未声明的deps(也许是genericentityejb吗?)
  • loginserver文件夹中的
  • :mvn clean package
  • 检查loginserver/target/loginserver-0.0.3-SNAPSHOT.war!/WEB-INF/lib/genericentityejb-1.0.3-SNAPSHOT.jarloginserver/target/loginserver-0.0.3-SNAPSHOT.war!/WEB-INF/lib/authobjects-0.0.3-SNAPSHOT.jar是否存在并包含所有实体类。

  • 此外,查看loginserver effective POM可能会很有用

    pom.xmlsettings.xml声明存储库是个人选择。两种方法各有利弊:
  • 复制粘贴存储库
  • pom:对于每个新项目
  • 设置:对于每台新机器(开发人员,CI env等)
  • 编辑 repo 网址
  • pom:对于每个项目
  • 设置:每台机器
  • 释放 Artifact 时的
  • :
  • pom:该版本的 repo 引用被刻在石头上
  • 设置:该版本中使用的 repo 引用未保存
  • 10-06 08:54