您可以修改 Wildfly JNDi 名称并从各自的 JNDI 名称中去除不需要的前缀,以在两个应用服务器中找到最小公分母。以下适用于 Glassfish 和 JBoss AS 7.1。由于我希望 Wildfly 在这方面向后兼容 JBoss,我想它也适用于 Wildfly。
持久性
注入为:
@PersistenceContext(unitName="TestPU")
private EntityManager entityManager;
或通过ejb-jar.xml:
<persistence-context-ref>
<persistence-context-ref-name>entityManager</persistence-context-ref-name>
<persistence-unit-name>TestPU</persistence-unit-name>
<injection-target> ... </injection-target>
</persistence-context-ref>
对应的persistence.xml:
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
<persistence-unit name="TestPU" transaction-type="JTA">
<jta-data-source>datasources/TestDS</jta-data-source>
<class>org.jeeventstore.persistence.jpa.EventStoreEntry</class>
<properties>
<property name="hibernate.show_sql" value="false"/>
<property name="hibernate.format_sql" value="true"/>
<property name="hibernate.hbm2ddl.auto" value="create-drop"/>
<property name="hibernate.connection.charSet" value="UTF-8"/>
<property name="eclipselink.logging.level" value="FINE"/>
<property name="eclipselink.logging.level.sql" value="FINE"/>
<property name="eclipselink.logging.parameters" value="true"/>
<property name="eclipselink.ddl-generation" value="drop-and-create-tables"/>
</properties>
</persistence-unit>
</persistence>
(注意简单的jta-data-sourceJNDI 名称)
这是一个glassfish-resources.xml 文件,用于指定部署时的 Derby 数据库,类似的设置可用于 MySQL 或 Postgres。
<resources>
<jdbc-resource pool-name="ArquillianEmbeddedDerbyPool"
jndi-name="datasources/TestDS"/>
<jdbc-connection-pool name="ArquillianEmbeddedDerbyPool"
res-type="javax.sql.DataSource"
datasource-classname="org.apache.derby.jdbc.EmbeddedDataSource"
is-isolation-level-guaranteed="false">
<property name="databaseName" value="target/databases/derby"/>
<property name="createDatabase" value="create"/>
</jdbc-connection-pool>
</resources>
还有来自 JBoss standalone.xml 的设置:
<datasource jta="true" jndi-name="java:/datasources/TestDS" pool-name="TestDS" enabled="true" use-ccm="false">
<connection-url>jdbc:postgresql://localhost/test_db</connection-url>
...
</datasource>
资源
我没有在 Glassfish 上注入 JavaMail 组件,但类似于数据源设置,可能值得尝试从 @Resource 注释中剥离“java:”部分。
@Resource(name = "mail/myMailSession")
然后配置 Wildfly,使邮件资源在“java:mail/myMailSession”JNDI 位置可用。
通过ejb-jar.xml注入
另一种选择是通过ejb-jar.xml 文件手动注入字段,然后使用构建工具(如maven)在组装时将ejb-jar-glassfish.xml 或ejb-jar-wildfly.xml 复制到所需的ejb-jar.xml。
在我们的一个项目中,我们使用混合方法来避免 xml 配置的负担:我们通过 ejb-jar.xml 配置少量“提供者”bean 来注入,例如,持久性上下文到 PersistenceContextProvider,然后使用 CDI 通过@EJB 将PersistenceContextProvider 注入到EJB 中,因为它们驻留在同一个EAR 中,所以无需进一步配置即可找到。