How do I make JNDI names compatible with both GlassFish and WildFly

前端 未结 3 1969
花落未央
花落未央 2021-02-06 06:37

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

3条回答
  •  说谎
    说谎 (楼主)
    2021-02-06 07:11

    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.

    Persistence

    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
        ...
    
    

    Resources

    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.

    Injection via 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.

提交回复
热议问题