【问题标题】:spring boot error - Caused by: java.lang.IllegalStateException: Could not configure JTA platformspring boot 错误 - 原因:java.lang.IllegalStateException:无法配置 JTA 平台
【发布时间】:2016-01-12 15:59:14
【问题描述】:
**I am using Java 6/Spring Framework 4.1.4/Spring Boot v1.2.1.RELEASE and Hibernate 3.5. 

由于我在 Java6 上,我使用嵌入式 Tomcat 7.0.59 为什么要尝试 JTA(或者我如何抑制 ComponentScan)? 此错误是什么意思以及如何解决?
我尝试使用单个注释而不是 SpringBootApplication 并且有相同的错误。 我正在尝试使用 Spring boot 创建服务,然后使用 Import Resource 加载 HB 连接等。**

我的应用程序属性:

server.port=2003
debug=true
spring.datasource.url=jdbc:oracle:thin:@***
spring.datasource.username=***
spring.datasource.password=***
spring.datasource.driverClassName=oracle.jdbc.driver.OracleDriver
spring.jpa.hibernate.dialect=org.hibernate.dialect.Oracle10gDialect**

我的 Gradle sn-p 是:

compile "org.springframework.security:spring-security-web:${springSecurityVersion}"
compile "org.springframework.security:spring-security-config:${springSecurityVersion}"
compile "org.springframework:spring-context:${springVersion}"
compile "org.springframework:spring-web:${springVersion}"
compile "org.springframework:spring-webmvc:${springVersion}"
compile "org.springframework:spring-jms:${springVersion}"
compile "org.springframework:spring-orm:${springVersion}"
compile "org.springframework:spring-jdbc:${springVersion}"
compile "org.springframework.boot:spring-boot-starter-web:${springBootVersion}"
compile "org.springframework.boot:spring-boot-starter-actuator:${springBootVersion}"

代码:

package com.mine.apps.force;
import com.mine.common.ErrorLog;    
@Controller
@EnableAutoConfiguration
@ComponentScan("com.mine")
//@ImportResource("classpath:webserver/forceAppContext.xml")
@RequestMapping(value="/force")
public class forceMicroService
{   
    private static ErrorLog logger = new ErrorLog("forceMicroService");

      public forceMicroService()
      {
      }


      @RequestMapping(value="/retry/{Id}", method=RequestMethod.POST)
      @ResponseBody
      String sendToforce(@PathVariable("Id") String Id)
      {
          String func = "sendToforce";

          logger.Info(func, "Entering");
          return Id;
    }

    public static void main(String[] args)
    {
          SpringApplication.run(forceMicroService.class, args);
    }
}

堆栈跟踪是

10:06:11,443 WARN  [embedded.AnnotationConfigEmbeddedWebApplicationContext]: Exception

在上下文初始化期间遇到 - 取消刷新尝试 org.springframework.beans.factory.BeanCreationException:创建类路径中定义的名称为“entityManagerFactory”的bean时出错 资源 [org/springframework/boot/autoconfigure/orm/jpa/HibernateJpaAutoConfiguration.class]: 通过工厂方法实例化 Bean 失败;嵌套异常是 org.springframework.beans.BeanInstantiationException:失败 实例化 [org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean]: 工厂方法“entityManagerFactory”抛出异常;嵌套的 异常是 java.lang.IllegalStateException: 无法配置 JTA 平台 在 org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:599) 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1111) 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1006) 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:504) 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:476) 在 org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:303) 在 org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230) 在 org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:299) 在 org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:194) 在 org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:956) 在 org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:747) 在 org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:480) 在 org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:118) 在 org.springframework.boot.SpringApplication.refresh(SpringApplication.java:691) 在 org.springframework.boot.SpringApplication.run(SpringApplication.java:321) 在 org.springframework.boot.SpringApplication.run(SpringApplication.java:961) 在 org.springframework.boot.SpringApplication.run(SpringApplication.java:950) 在 com.vzw.etm.apps.enforce.EnforceMicroService.main(EnforceMicroService.java:47) 引起:org.springframework.beans.BeanInstantiationException:无法实例化 [org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean]: 工厂方法“entityManagerFactory”抛出异常;嵌套的 异常是 java.lang.IllegalStateException: 无法配置 JTA 平台 在 org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:189) 在 org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:588) ... 17 更多 原因:java.lang.IllegalStateException:无法配置 JTA 平台 在 org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration.getNoJtaPlatformManager(HibernateJpaAutoConfiguration.java:151) 在 org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration.configureJtaPlatform(HibernateJpaAutoConfiguration.java:129) 在 org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration.customizeVendorProperties(HibernateJpaAutoConfiguration.java:99) 在 org.springframework.boot.autoconfigure.orm.jpa.JpaBaseConfiguration.entityManagerFactory(JpaBaseConfiguration.java:111) 在 org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration$$EnhancerBySpringCGLIB$$6ecd1b06.CGLIB$entityManagerFactory$6() 在 org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration$$EnhancerBySpringCGLIB$$6ecd1b06$$FastClassBySpringCGLIB$$797c76e5.invoke() 在 org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:228) 在 org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:309) 在 org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration$$EnhancerBySpringCGLIB$$6ecd1b06.entityManagerFactory() 在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 在 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 在 java.lang.reflect.Method.invoke(Method.java:597) 在 org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:162) ... 18 更多 10:06:11,465 信息 [concurrent.ThreadPoolTask​​Executor]:关闭 ExecutorService 'metricsExecutor' 2016 年 1 月 12 日上午 10:06:11 org.apache.catalina.core.StandardService stopInternal 信息:停止服务 Tomcat

【问题讨论】:

  • 请提供一些您尝试做的事情的背景......
  • 我正在尝试使用 Boot/Tomcat 创建服务。 Sprign 似乎进行了自动扫描,并正在尝试 JPA 连接。真正的逻辑在我在代码中的上下文 xml 中(已注释掉)。
  • 基本上采用现有代码并将它们转换为基于引导的服务。代码库是 JDBC/Hibernate/SOAP 服务和 REST 服务的混合体。所以目的是把一些非基于WS的调用转换成服务
  • 您的服务将部署为带有嵌入式 Tomcat 的可执行 JAR,还是将其部署在应用服务器中?

标签: java spring hibernate spring-boot


【解决方案1】:

Spring Boot 不支持 Hibernate 3.5。
最低要求版本是 Hibernate 4.2。

您可以通过完全禁用 Hibernate 的自动配置来解决此问题:

@EnableAutoConfiguration(exclude = {HibernateJpaAutoConfiguration.class})

如果您确实将服务部署为带有嵌入式 Tomcat 的可执行 JAR,则没有理由使用这么旧的 Hibernate 版本,因此您应该使用 Spring Boot 定义的版本。

【讨论】:

  • 成功了。非常感谢。这就提出了一个关于我应该在哪里应用 Spring Boot 的新问题。
  • 除了这个 bean,我还必须排除 JpaRepositoriesAutoConfiguration.class 才能使其工作。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2020-02-20
  • 2021-10-02
  • 2021-08-02
  • 2015-12-21
  • 1970-01-01
  • 2016-03-03
  • 2021-03-03
相关资源
最近更新 更多