无法将Hibernate会话工厂绑定到WildFly 8.2.1中的java:app

时间:2015-10-13 22:26:44

标签: java hibernate jpa jndi wildfly

我正在尝试从部署到WildFly 8.2.1的应用程序中的持久性单元注册Hibernate Session Factory,并且我遇到来自Hibernate 4代码的警告异常(如下所列)。当我在WildFly控制台中查看JNDI时,会话工厂肯定没有注册。我希望他们能够进入" java:app"范围,以便当多个应用程序可能具有相同的会话工厂名称时,我可以避免命名冲突。

将实体管理器注册到此范围可以正常工作。

如果我离开" java:app"会话工厂名称的前缀,它可以很好地绑定到JNDI,但是在全局范围内。我知道我可以施加某种名称间距,但我希望我不必这样做。

任何输入都将不胜感激。谢谢。

以下详细信息......

持久性单元

<persistence-unit name="myPU" transaction-type="JTA">
    <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
    <jta-data-source>java:/jdbc/MyDS</jta-data-source>
    <exclude-unlisted-classes>true</exclude-unlisted-classes>
    <mapping-file>MySchema.hbm.xml</mapping-file>
    <properties>
        <property name="jboss.entity.manager.jndi.name" value="java:app/em/MY_EM" />
        <property name="hibernate.session_factory_name" value="java:app/sessions/my_FACTORY"/>
        <property name="hibernate.query.imports" value="com.my.model" />
        <property name="hibernate.current_session_context_class" value="thread" />
        <property name="hibernate.use_outer_join" value="true" />
        <property name="hibernate.jdbc.use_streams_for_binary" value="true" />
        <property name="hibernate.dialect" value="org.hibernate.dialect.OracleDialect" />
    </properties>
</persistence-unit>

例外摘要

  

16:14:50,044 WARN [org.hibernate.internal.SessionFactoryRegistry](ServerService线程池 - 64) - HHH000277:无法将工厂绑定到JNDI:org.hibernate.engine.jndi.JndiException:创建中间上下文时出错[java的:应用]

     

引起:javax.naming.NameNotFoundException:java:app

来自Hibernate的完全警告异常

  

16:14:50,044 WARN [org.hibernate.internal.SessionFactoryRegistry](ServerService线程池 - 64) - HHH000277:无法将工厂绑定到JNDI:org.hibernate.engine.jndi.JndiException:创建中间上下文时出错[java的:应用]           在org.hibernate.engine.jndi.internal.JndiServiceImpl.bind(JndiServiceImpl.java:205)[hibernate-core-4.3.7.Final.jar:4.3.7.Final]           在org.hibernate.engine.jndi.internal.JndiServiceImpl.bind(JndiServiceImpl.java:159)[hibernate-core-4.3.7.Final.jar:4.3.7.Final]           在org.hibernate.internal.SessionFactoryRegistry.addSessionFactory(SessionFactoryRegistry.java:103)[hibernate-core-4.3.7.Final.jar:4.3.7.Final]           在org.hibernate.internal.SessionFactoryImpl。(SessionFactoryImpl.java:497)[hibernate-core-4.3.7.Final.jar:4.3.7.Final]           在org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1859)[hibernate-core-4.3.7.Final.jar:4.3.7.Final]           在org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl $ 4.perform(EntityManagerFactoryBuilderImpl.java:852)[hibernate-entitymanager-4.3.7.Final.jar:4.3.7.Final]           在org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl $ 4.perform(EntityManagerFactoryBuilderImpl.java:845)[hibernate-entitymanager-4.3.7.Final.jar:4.3.7.Final]           在org.hibernate.boot.registry.classloading.internal.ClassLoaderServiceImpl.withTccl(ClassLoaderServiceImpl.java:398)[hibernate-core-4.3.7.Final.jar:4.3.7.Final]           在org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:844)[hibernate-entitymanager-4.3.7.Final.jar:4.3.7.Final]           在org.jboss.as.jpa.hibernate4.TwoPhaseBootstrapImpl.build(TwoPhaseBootstrapImpl.java:44)[jipijapa-hibernate4-3-1.0.1.Final.jar:]           在org.jboss.as.jpa.service.PersistenceUnitServiceImpl $ 1 $ 1.run(PersistenceUnitServiceImpl.java:154)[wildfly-jpa-8.2.1.Final.jar:8.2.1.Final]           在org.jboss.as.jpa.service.PersistenceUnitServiceImpl $ 1 $ 1.run(PersistenceUnitServiceImpl.java:117)[wildfly-jpa-8.2.1.Final.jar:8.2.1.Final]           at java.security.AccessController.doPrivileged(Native Method)[rt.jar:1.8.0_51]           在org.wildfly.security.manager.WildFlySecurityManager.doChecked(WildFlySecurityManager.java:474)[wildfly-security-manager-1.0.0.Final.jar:1.0.0.Final]           在org.jboss.as.jpa.service.PersistenceUnitServiceImpl $ 1.run(PersistenceUnitServiceImpl.java:182)[wildfly-jpa-8.2.1.Final.jar:8.2.1.Final]           在java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)[rt.jar:1.8.0_51]           at java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.java:617)[rt.jar:1.8.0_51]           在java.lang.Thread.run(Thread.java:745)[rt.jar:1.8.0_51]           在org.jboss.threads.JBossThread.run(JBossThread.java:122)   引起:javax.naming.NameNotFoundException:java:app           at org.jboss.as.naming.InitialContext $ DefaultInitialContext.findContext(InitialContext.java:187)[wildfly-naming-8.2.1.Final.jar:8.2.1.Final]           at org.jboss.as.naming.InitialContext $ DefaultInitialContext.createSubcontext(InitialContext.java:294)[wildfly-naming-8.2.1.Final.jar:8.2.1.Final]           在org.jboss.as.naming.NamingContext.createSubcontext(NamingContext.java:398)[wildfly-naming-8.2.1.Final.jar:8.2.1.Final]           在javax.naming.InitialContext.createSubcontext(InitialContext.java:489)[rt.jar:1.8.0_51]           在javax.naming.InitialContext.createSubcontext(InitialContext.java:489)[rt.jar:1.8.0_51]           在org.hibernate.engine.jndi.internal.JndiServiceImpl.bind(JndiServiceImpl.java:202)[hibernate-core-4.3.7.Final.jar:4.3.7.Final]           ......还有18个

1 个答案:

答案 0 :(得分:0)

我可能找到了答案......

虽然这不是我想要的答案。但是,这是有道理的。 Hibernate的JNDI绑定机器人无法找到java:app子上下文的原因是因为,我认为它试图在根处找到该名称并且在那里不存在。另一方面,JBoss / WildFly在部署应用程序时似乎有一些隐式上下文,实际上是在JNDI树中java:app下存在的applications/<module-name>。 Hibernate对这个结构一无所知。

我修改了我的实现是按照JNDI树的根目录按应用程序名称组织这些会话工厂绑定,如下所示:

hib > myApp > sessions > MY_SESSION_FACTORY

我希望这可以帮助其他人。