骆驼 3 openjdk 11 hibernate/jpa java.lang.NoSuchMethodError
camel 3 openjdk 11 hibernate/jpa java.lang.NoSuchMethodError
我正在尝试迁移一个曾经与 camel 2 和 jdk 8 一起工作的 maven 项目。我正在尝试同时使用更新版本的 spring 和休眠。
清理我的本地 maven .m2/ 存储库后,"mvn clean install" 工作然后尝试 "mvn clean package exec:java",我有一个 java.lang.NoSuchMethodError 似乎链接到 spring-核心
我的 spring xml 配置文件导入一个 databaseconfig.xml 文件,即:
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:jpa="http://www.springframework.org/schema/data/jpa"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
http://www.springframework.org/schema/data/jpa
http://www.springframework.org/schema/data/jpa/spring-jpa-1.3.xsd">
<!-- bean post processor to add advisor to repository bean so platform specific exceptions are caught efficiently ie. unchecked -->
<bean class="org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor"/>
<!-- needed so entitymanager can be injected in spring inside pricevectordaojpa -->
<bean class="org.springframework.orm.jpa.support.PersistenceAnnotationBeanPostProcessor"/>
<context:property-placeholder location="classpath:config.properties"/>
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="${db.driverClassName}"/>
<property name="url" value="${db.url}"/>
<property name="username" value="${db.username}"/>
<property name="password" value="${db.password}"/>
</bean>
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="jpaVendorAdapter">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
<property name="database" value="${db.type}" />
<property name="showSql" value="false" />
</bean>
</property>
<property name="dataSource" ref="dataSource" />
<property name="packagesToScan" value="com.nodenet.domain" />
<property name="jpaProperties">
<props>
<prop key="hibernate.ejb.naming_strategy">${db.namingStrategy}</prop>
<prop key="hibernate.hbm2ddl.auto">${db.hbm2ddl}</prop>
</props>
</property>
</bean>
<bean id="jpa" class="org.apache.camel.component.jpa.JpaComponent">
<property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>
<bean id="jpaTransactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory"/>
</bean>
<tx:annotation-driven transaction-manager="jpaTransactionManager"/>
</beans>
看起来这是文件造成了一些问题,因为找不到一些 spring-core class/dependency 因为我收到以下错误:
根据 burki 的评论,我在我的 pom.xml 中使用 enforcer maven 插件和排除项清理了可传递的 spring 依赖项并且它起作用了
我猜你 混合了 Spring 不同版本的依赖关系 。可能存在由其他依赖项(如 ActiveMQ 或其他)拉动的传递 Spring 依赖项。
所有 Spring 框架依赖项必须具有相同的版本,在您的情况下为 5.1.14.RELEASE。
使用 IDE 的 依赖管理来获取所有项目依赖的列表或使用 Maven dependency plugin to list a tree of your dependencies。
您还可以使用Maven enforcer plugin 来解决依赖冲突。但我认为它不会抱怨旧版本的个别 Spring 依赖项。
替代自我管理
另一个策略是利用 Spring 引导社区的出色工作来构建一个运行良好的依赖版本生态系统。
注意下面的定义只是添加了依赖管理,并不是真正的依赖!
您可以通过将 Spring 引导 POM 声明为您的父 POM 来使用它。
<parent>
<artifactId>spring-boot-starter-parent</artifactId>
<groupId>org.springframework.boot</groupId>
<version>2.1.7.RELEASE</version>
<relativePath />
</parent>
如果你不使用SpringBoot或者你的parent已经在使用,你也可以只使用依赖管理部分。此版本 仅定义依赖版本 而 父 POM 还定义 Maven 插件版本 .
<dependencyManagement>
<dependencies>
<dependency>
<!-- Import dependency management from Spring Boot -->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.1.7.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
使用 POM 中的这些定义之一,您可以忽略大多数依赖版本以使用 Spring Boot.
这里以dependency definitions of Spring Boot version 2.1.7为例。
Spring Boot docs 中描述了两种变体以获取更多详细信息。
我正在尝试迁移一个曾经与 camel 2 和 jdk 8 一起工作的 maven 项目。我正在尝试同时使用更新版本的 spring 和休眠。
清理我的本地 maven .m2/ 存储库后,"mvn clean install" 工作然后尝试 "mvn clean package exec:java",我有一个 java.lang.NoSuchMethodError 似乎链接到 spring-核心
我的 spring xml 配置文件导入一个 databaseconfig.xml 文件,即:
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:jpa="http://www.springframework.org/schema/data/jpa"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
http://www.springframework.org/schema/data/jpa
http://www.springframework.org/schema/data/jpa/spring-jpa-1.3.xsd">
<!-- bean post processor to add advisor to repository bean so platform specific exceptions are caught efficiently ie. unchecked -->
<bean class="org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor"/>
<!-- needed so entitymanager can be injected in spring inside pricevectordaojpa -->
<bean class="org.springframework.orm.jpa.support.PersistenceAnnotationBeanPostProcessor"/>
<context:property-placeholder location="classpath:config.properties"/>
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="${db.driverClassName}"/>
<property name="url" value="${db.url}"/>
<property name="username" value="${db.username}"/>
<property name="password" value="${db.password}"/>
</bean>
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="jpaVendorAdapter">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
<property name="database" value="${db.type}" />
<property name="showSql" value="false" />
</bean>
</property>
<property name="dataSource" ref="dataSource" />
<property name="packagesToScan" value="com.nodenet.domain" />
<property name="jpaProperties">
<props>
<prop key="hibernate.ejb.naming_strategy">${db.namingStrategy}</prop>
<prop key="hibernate.hbm2ddl.auto">${db.hbm2ddl}</prop>
</props>
</property>
</bean>
<bean id="jpa" class="org.apache.camel.component.jpa.JpaComponent">
<property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>
<bean id="jpaTransactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory"/>
</bean>
<tx:annotation-driven transaction-manager="jpaTransactionManager"/>
</beans>
看起来这是文件造成了一些问题,因为找不到一些 spring-core class/dependency 因为我收到以下错误:
根据 burki 的评论,我在我的 pom.xml 中使用 enforcer maven 插件和排除项清理了可传递的 spring 依赖项并且它起作用了
我猜你 混合了 Spring 不同版本的依赖关系 。可能存在由其他依赖项(如 ActiveMQ 或其他)拉动的传递 Spring 依赖项。
所有 Spring 框架依赖项必须具有相同的版本,在您的情况下为 5.1.14.RELEASE。
使用 IDE 的 依赖管理来获取所有项目依赖的列表或使用 Maven dependency plugin to list a tree of your dependencies。
您还可以使用Maven enforcer plugin 来解决依赖冲突。但我认为它不会抱怨旧版本的个别 Spring 依赖项。
替代自我管理
另一个策略是利用 Spring 引导社区的出色工作来构建一个运行良好的依赖版本生态系统。
注意下面的定义只是添加了依赖管理,并不是真正的依赖!
您可以通过将 Spring 引导 POM 声明为您的父 POM 来使用它。
<parent>
<artifactId>spring-boot-starter-parent</artifactId>
<groupId>org.springframework.boot</groupId>
<version>2.1.7.RELEASE</version>
<relativePath />
</parent>
如果你不使用SpringBoot或者你的parent已经在使用,你也可以只使用依赖管理部分。此版本 仅定义依赖版本 而 父 POM 还定义 Maven 插件版本 .
<dependencyManagement>
<dependencies>
<dependency>
<!-- Import dependency management from Spring Boot -->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.1.7.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
使用 POM 中的这些定义之一,您可以忽略大多数依赖版本以使用 Spring Boot.
这里以dependency definitions of Spring Boot version 2.1.7为例。
Spring Boot docs 中描述了两种变体以获取更多详细信息。