我正在尝试从部署到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个
答案 0 :(得分:0)
我可能找到了答案......
虽然这不是我想要的答案。但是,这是有道理的。 Hibernate的JNDI绑定机器人无法找到java:app
子上下文的原因是因为,我认为它试图在根处找到该名称并且在那里不存在。另一方面,JBoss / WildFly在部署应用程序时似乎有一些隐式上下文,实际上是在JNDI树中java:app
下存在的applications/<module-name>
。 Hibernate对这个结构一无所知。
我修改了我的实现是按照JNDI树的根目录按应用程序名称组织这些会话工厂绑定,如下所示:
hib > myApp > sessions > MY_SESSION_FACTORY
我希望这可以帮助其他人。