I am developing a Java EE 7 application and have a requirement for the application to be deployed onto application servers running either GlassFish 4.0 or WildFly 8.1.0. The iss
You can modify the Wildfly JNDi names and strip the undesired prefixes from the respective JNDI names to find the least common denominator in both app servers. The following works for me with Glassfish and JBoss AS 7.1. Since I expect Wildfly to be backwards-compatible to JBoss in this regard, I guess it'll work for Wildfly as well.
Inject as:
@PersistenceContext(unitName="TestPU")
private EntityManager entityManager;
or via ejb-jar.xml
:
entityManager
TestPU
...
The corresponding persistence.xml
:
datasources/TestDS
org.jeeventstore.persistence.jpa.EventStoreEntry
(note the simple jta-data-source
JNDI name)
Here's a glassfish-resources.xml
file used to specify a Derby database on deployment, a similar setup can be used for MySQL or Postgres.
And the settings from the JBoss standalone.xml
:
jdbc:postgresql://localhost/test_db
...
I have not injected a JavaMail component on Glassfish, but similar to the datasoruce settings, it might be worth a try to strip the "java:
" part from the @Resource
annotation as well.
@Resource(name = "mail/myMailSession")
and then configure Wildfly such that that the mail resource is available at the "java:mail/myMailSession
" JNDI location.
ejb-jar.xml
Another option is to manually inject the fields via a ejb-jar.xml
file, and then use a build tool such as maven to copy either of ejb-jar-glassfish.xml
or ejb-jar-wildfly.xml
to the desired ejb-jar.xml
at assembly time.
In one of our projects we use a mixed approach to avoid the burden with the xml configuration: We configure a small number of "provider" beans via ejb-jar.xml
to inject, e.g., the persistence context into a PersistenceContextProvider
, and then use CDI to inject the PersistenceContextProvider
into the EJBs via @EJB
, which are found without further configuration since they reside in the same EAR.