Bitronix 配置与 tomcat 抛出 jndi 异常

Posted

技术标签:

【中文标题】Bitronix 配置与 tomcat 抛出 jndi 异常【英文标题】:Bitronix configuration with tomcat throw jndi exception 【发布时间】:2017-05-11 04:01:35 【问题描述】:

我是 bitronix 的新手,我的应用程序中需要 xa 事务。

我正在尝试使用 spring 配置 bitronix,但我在启动 tomcat 时遇到异常。

感谢任何帮助。

原因:org.hibernate.engine.jndi.JndiException:无法查找 JNDI 名称 [javax.transaction.TransactionManager] 在 org.hibernate.engine.jndi.internal.JndiServiceImpl.locate(JndiServiceImpl.java:117) 在 org.hibernate.engine.transaction.jta.platform.internal.WeblogicJtaPlatform.locateTransactionManager(WeblogicJtaPlatform.java:41) org.hibernate.engine.transaction.jta.platform.internal.AbstractJtaPlatform.canRegisterSynchronization(AbstractJtaPlatform.java:148) 在 org.hibernate.engine.transaction.internal.TransactionCoordinatorImpl.attemptToRegisterJtaSync(TransactionCoordinatorImpl.java:252) 在 org.hibernate.engine.transaction.internal.TransactionCoordinatorImpl.pulse(TransactionCoordinatorImpl.java:289) 在 org.hibernate.jpa.spi.AbstractEntityManagerImpl.joinTransaction(AbstractEntityManagerImpl.java:1584) 在 org.hibernate.jpa.spi.AbstractEntityManagerImpl.postInit(AbstractEntityManagerImpl.java:210) 在 org.hibernate.jpa.internal.EntityManagerImpl.(EntityManagerImpl.java:91) 在 org.hibernate.jpa.internal.EntityManagerFactoryImpl.internalCreateEntityManager(EntityManagerFactoryImpl.java:345) 在 org.hibernate.jpa.internal.EntityManagerFactoryImpl.createEntityManager(EntityManagerFactoryImpl.java:313) 在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 在 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 在 java.lang.reflect.Method.invoke(Method.java:606) 在 org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.invokeProxyMethod(AbstractEntityManagerFactoryBean.java:407) 在 org.springframework.orm.jpa.AbstractEntityManagerFactoryBean$ManagedEntityManagerFactoryInvocationHandler.invoke(AbstractEntityManagerFactoryBean.java:560) 在 com.sun.proxy.$Proxy78.createEntityManager(未知来源) 在 org.springframework.orm.jpa.SharedEntityManagerCreator$SharedEntityManagerInvocationHandler.invoke(SharedEntityManagerCreator.java:288) 在 com.sun.proxy.$Proxy83.getDelegate(未知来源) 在 org.springframework.data.jpa.provider.PersistenceProvider.fromEntityManager(PersistenceProvider.java:295) 原因:javax.naming.NameNotFoundException:名称 [javax.transaction.TransactionManager] 未绑定在此上下文中。找不到 [javax.transaction.TransactionManager]。 在 org.apache.naming.NamingContext.lookup(NamingContext.java:818) 在 org.apache.naming.NamingContext.lookup(NamingContext.java:152) 在 org.apache.naming.SelectorContext.lookup(SelectorContext.java:134) 在 javax.naming.InitialContext.lookup(InitialContext.java:415) 在 org.hibernate.engine.jndi.internal.JndiServiceImpl.locate (JndiServiceImpl.java:114)

【问题讨论】:

【参考方案1】:

从您的堆栈跟踪看来,您正在 tomcat 中运行您的应用程序,因此请确保以下几点:

1) 你的 pom.xml 或项目特定的 lib 文件夹中不应有任何 jta、bitronix 相关的 jar,因为这些 jar 应该在你的 tomcat lib 文件夹中。

2) 还要根据文件修改server.xml和context.xml这两个文件存在于tomcat的conf文件夹中。

我不确定您的 jndi 查找配置是什么。您可以通过以下链接为 tomcat 设置 bitronix。

https://github.com/bitronix/btm/blob/master/btm-docs/src/main/asciidoc/TomcatWithBtm2x.adoc

【讨论】:

@ 启动。谢谢它解决了我的问题。我的应用程序的 META-INF 文件夹下没有 context.xml。

以上是关于Bitronix 配置与 tomcat 抛出 jndi 异常的主要内容,如果未能解决你的问题,请参考以下文章

JN_0016:查找端口占用

JN5169 ZigBee 3.0 协议栈之 ZPS 配置编辑器

使用 spring-data-jpa 和完整的 tomcat-jdbc 配置的 spring boot 为 ResetAbandonedTimer 抛出 java.lang.ClassNotFound

NXP JN5189 内存分析工具 Gawk

NXP JN5189 内存分析工具 Gawk

NXP JN5189 ZigBee 3.0开发环境搭建