使用单个 JAR 文件的复合持久性单元

Composite Persistence Unit using a single JAR file

我已经在网上和这个网站上搜索过答案。虽然我通过 Google 搜索找到了一个 link,但后来我丢失了 link,再也找不到了。

我一直在 Glassfish 4.1.1 上开发电子商务网站 运行,该网站最初只有一个使用 EclipseLink 2.6.4 的数据库 (DB),但现在需要三个驻留在多个服务器(为了保证客户数据的安全)。该站点在单个数据库上运行良好。我将单个数据库中的数据分成三个。 J2EE 代码中定义的实体和 JPA 控制器都是相同的(我保留了代码,这样我就不必重写所有内容,只需进行一些小的更改,例如注释等),但它们现在位于三个不同的 MySQL 数据库。三个数据库相互关联。

理论上(并且根据 link 我看到并丢失了)可以定义复合持久性单元 (PU) 以将三个不同数据源的所有三个 PU 合并到一个 JAR 文件中,并且使用实体-PU 映射的标签。大多数示例(以及 Eclipselink 和 Oracle Persistence API 文档)使用具有多个 JAR 文件的复合 PU(例如:https://github.com/forgemo/eclipselink-composite-persistence-unit-example)。

关于如何创建复合 PU 而不必为每个数据库 PU 使用单独的 JAR 文件,谁能给我指出正确的方向?

我当前的 persistence.xml 文件(多个 PU 但不是复合)如下:

<?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="PU1" transaction-type="JTA">
    <jta-data-source>java:app/jdbc/db1</jta-data-source>
    <class>com.mysite.myproject.Database.Items</class>
    <class>com.mysite.myproject.Database.Manufacturer</class>
    <class>com.mysite.myproject.Database.Category</class>
    <class>com.mysite.myproject.Database.Cart</class>
    <class>com.mysite.myproject.Database.AuditTable</class>
    <class>com.mysite.myproject.Database.Images</class>
    <class>com.mysite.myproject.Database.Procedures</class>
    <class>com.mysite.myproject.Database.Warehouse</class>
    <class>com.mysite.myproject.Database.Wishlist</class>
    <class>com.mysite.myproject.Database.Purchases</class>
    <class>com.mysite.myproject.Database.TaxTables</class>
    <exclude-unlisted-classes>true</exclude-unlisted-classes>
    <properties>
        <property name="javax.persistence.schema-generation.database.action" value="drop-and-create"/>
        <property name="eclipselink.logging.level" value="FINE"/>
    </properties>
</persistence-unit>

<persistence-unit name="PU2" transaction-type="JTA">
    <jta-data-source>java:app/jdbc/db2</jta-data-source>
    <class>com.mysite.myproject.Database.AccessList</class>
    <class>com.mysite.myproject.Database.Users</class>
    <class>com.mysite.myproject.Database.Customer</class>
    <exclude-unlisted-classes>true</exclude-unlisted-classes>
    <properties>
        <property name="javax.persistence.schema-generation.database.action" value="drop-and-create"/>
        <property name="eclipselink.logging.level" value="FINE"/>
    </properties>
</persistence-unit>

<persistence-unit name="PU3" transaction-type="JTA">
    <jta-data-source>java:app/jdbc/db3</jta-data-source>
    <class>com.mysite.myproject.Database.Key1</class>
    <class>com.mysite.myproject.Database.Key2</class>
    <class>com.mysite.myproject.Database.Key3</class>
    <class>com.mysite.myproject.Database.Key4</class>
    <exclude-unlisted-classes>true</exclude-unlisted-classes>
    <properties>
        <property name="javax.persistence.schema-generation.database.action" value="create"/>
        <property name="eclipselink.logging.level" value="FINE"/>
    </properties>
</persistence-unit>

只要数据源之间没有关系,上述 persistence.xml 就可以正常工作(例如 - Wishlist 和 Customer 表之间的关系导致“[class com.mysite.myproject.Database.Wishlist] 使用非实体 [class com.mysite.myproject.Database.Customer] 作为关系属性 [field customer] 中的目标实体”在部署时)。

事实证明,似乎不需要复合持久化单元(这可能解释了为什么没有人能回答这个问题,而且关于它们的文档很少)。

在 Glassfish、Geronimo、WebLogic、Ecplipselink 和 NetBeans 中发现许多错误后,我终于能够使用多个持久性单元 (PU) 而无需使用复合 PU 来使系统工作。 JTA 能够保留所有实体,包括它们对自己 PU 之外的实体的引用。使这项工作成功的一个关键因素是确保不排除 类 不是 PU 的一部分,方法是将其添加到 persistence.xml:

中的 PU 定义中
<exclude-unlisted-classes>false</exclude-unlisted-classes>

如以下完整的 PU 示例(我在项目中使用的三个之一):

<persistence-unit name="DHWPU" transaction-type="JTA">
    <jta-data-source>jdbc/dhw</jta-data-source>
    <class>Database.AuditTable</class>
    <class>Database.Cart</class>
    <class>Database.Category</class>
    <class>Database.Images</class>
    <class>Database.Items</class>
    <class>Database.Manufacturer</class>
    <class>Database.Procedures</class>
    <class>Database.Purchases</class>
    <class>Database.TaxTables</class>
    <class>Database.Warehouse</class>
    <class>Database.Wishlist</class>
    <exclude-unlisted-classes>false</exclude-unlisted-classes>

    <properties>
        <property name="javax.persistence.schema-generation.database.action" value="none"/>
        <property name="eclipselink.logging.level" value="FINE"/>
    </properties>
</persistence-unit>