**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启动来创建服务,然后使用导入资源来加载HB连接等 . **
我的application.properties:
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片段是:
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]:异常
在上下文初始化期间遇到 - 取消刷新尝试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:无法在org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:599)的org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod上配置JTA平台(在org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1006)的org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:504)org上的AbstractAutowireCapableBeanFactory.java:1111) .springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:476)位于org.springframework.beans.factory的org.springframework.beans.factory.support.AbstractBeanFactory $ 1.getObject(AbstractBeanFactory.java:303) . support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBean Registry.java:230)org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:299)org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:194)at 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(Sprin) gApplication.java:950)at com.vzw.etm.apps.enforce.EnforceMicroService.main(EnforceMicroService.java:47)引起:org.springframework.beans.BeanInstantiationException:无法实例化[org.springframework.orm.jpa . LocalContainerEntityManagerFactoryBean]:工厂方法'entityManagerFactory'抛出异常;嵌套异常是java.lang.IllegalStateException:无法在org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod上的org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:189)中配置JTA平台( ConstructorResolver.java:588)... 17更多引起:java.lang.IllegalStateException:无法在org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration.getNoJtaPlatformManager(HibernateJpaAutoConfiguration.java:151)的org配置JTA平台.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration.configureJtaPlatform(HibernateJpaAutoConfiguration.java:129)org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration.customizeVendorProperties(HibernateJpaAutoConfiguration.java:99)at atorg.springframework.boot.autoconfigure.orm.jpa.JpaBaseConfiguration.entityManagerFactory(JpaBaseConfiguration.java:111)at org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration $$ EnhancerBySpringCGLIB $$ 6ecd1b06.CGLIB $ entityManagerFactory $ 6()at at org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration $$ EnhancerBySpringCGLIB $$ 6ecd1b06 $$ FastClassBySpringCGLIB $$ 797c76e5.invoke()at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:228)at org .springframework.context.annotation.ConfigurationClassEnhancer $ BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:309)atg.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration $$ EnhancerBySpringCGLIB $$ 6ecd1b06.entityManagerFactory()at sun.reflect.NativeMethodAccessorImpl . 在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.j)的sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)中的invoke0(本机方法) ava:25)在java.lang.reflect.Method.invoke(Method.java:597)org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:162)... 18更多10:06 :11,465 INFO [concurrent.ThreadPoolTaskExecutor]:关闭ExecutorService'mempisionExecutor'2016年1月12日上午10:06:11 org.apache.catalina.core.StandardService stopInternal INFO:停止服务Tomcat
1 回答
Spring Boot不支持Hibernate 3.5 .
所需的最低版本是Hibernate 4.2 .
你可以通过完全禁用Hibernate的自动配置来解决这个问题:
如果您将服务部署为具有嵌入式Tomcat的可执行JAR,则没有理由使用这样的旧Hibernate版本,因此您应该使用Spring Boot定义的版本 .