首页 > 解决方案 > 尝试调用不存在的方法 com.github.cloudyrock.mongock.SpringMongockBuilderBase.lambda$getMongoTemplateProxySupplier

问题描述

使用 Mongock https://github.com/cloudyrock/mongock进行数据迁移 spring boot 2.3.1.RELEASE,以前使用 Mongobee 但由于此错误org.springframework.beans.factory.UnsatisfiedDependencyException:Error Creating bean with name 'mongoTemplate ' 以及大家建议改用Mongock尝试调用一个不存在的方法,mongo-java-driver,mongobee

现在我正在使用 Mongock 进行数据迁移,但不断出现错误

An attempt was made to call a method that does not exist. The attempt was made from the following location:

    com.github.cloudyrock.mongock.SpringMongockBuilderBase.lambda$getMongoTemplateProxySupplier$0(SpringMongockBuilderBase.java:138)

The following method did not exist:

    'org.springframework.data.mongodb.MongoDbFactory org.springframework.data.mongodb.core.MongoTemplate.getMongoDbFactory()'

The method's class, org.springframework.data.mongodb.core.MongoTemplate, is available from the following locations:

    jar:file:/Users/macbook/.gradle/caches/modules-2/files-2.1/org.springframework.data/spring-data-mongodb/3.0.1.RELEASE/24961d107813268bb9cd3daa8d4a9389060faea7/spring-data-mongodb-3.0.1.RELEASE.jar!/org/springframework/data/mongodb/core/MongoTemplate.class

The class hierarchy was loaded from the following locations:

    org.springframework.data.mongodb.core.MongoTemplate: file:/Users/macbook/.gradle/caches/modules-2/files-2.1/org.springframework.data/spring-data-mongodb/3.0.1.RELEASE/24961d107813268bb9cd3daa8d4a9389060faea7/spring-data-mongodb-3.0.1.RELEASE.jar


Action:

Correct the classpath of your application so that it contains a single, compatible version of org.springframework.data.mongodb.core.MongoTemplate

这是错误是由于我知道但不知道如何解决的依赖关系

plugins {
    id 'org.springframework.boot' version '2.3.1.RELEASE'
    id 'io.spring.dependency-management' version '1.0.9.RELEASE'
    id 'java'
}

group = 'fete.bird'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = '14'
compileJava {
    options.compilerArgs += ["--enable-preview"]
}
repositories {
    mavenCentral()
}
ext {
    set('springCloudVersion', "Hoxton.SR6")
}

dependencies {
    implementation 'org.springframework.boot:spring-boot-starter-data-rest'
    testImplementation('org.springframework.boot:spring-boot-starter-test') {
        exclude group: 'org.junit.vintage', module: 'junit-vintage-engine'
    }
    implementation 'org.springdoc:springdoc-openapi-ui:1.4.3'
    implementation 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-client'
    implementation 'org.springframework.boot:spring-boot-starter-actuator'
    developmentOnly 'org.springframework.boot:spring-boot-devtools'
    implementation 'org.springframework.cloud:spring-cloud-starter-config'
    implementation 'org.springframework.boot:spring-boot-starter-data-mongodb'

    compile "org.mongodb:mongo-java-driver:3.12.6"
    compile("com.github.cloudyrock.mongock:mongock-spring:3.3.2") {
        exclude group: 'org.mongodb', module: 'mongo-java-driver'
    }
}
dependencyManagement {
    imports {
        mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
    }
}

test {
    useJUnitPlatform()
}

标签: springspring-bootspring-data-mongodbmongo-java-drivermongock

解决方案


问题出在 mongock:mongock 上,更新到最新的 Beta 版本,通过添加工作解决了这个问题。

删除所有的mongock依赖并添加以下依赖

compile "com.github.cloudyrock.mongock:mongock-bom:4.1.2.BETA"
    compile 'com.github.cloudyrock.mongock:mongock-spring-v5:4.1.2.BETA'
    compile 'com.github.cloudyrock.mongock:mongodb-springdata-v3-driver:4.1.2.BETA'

现在 Bean 更改如下

  @Bean
    public MongockSpring5.MongockInitializingBeanRunner mongockInitializingBeanRunner(ApplicationContext springContext, MongoTemplate mongoTemplate) {
        boolean migrationsEnabled = Boolean.parseBoolean(environment.getProperty("app.db.migrations.enabled"));
        return MongockSpring5.builder()
                .setDriver(new SpringDataMongo3Driver(mongoTemplate,4,4,3))
                .addChangeLogsScanPackages(List.of("fete.bird.fetebirdproduct.migration"))
                .setSpringContext(springContext)
                .setEnabled(migrationsEnabled)
                .buildInitializingBeanRunner();
    }

参考

https://github.com/cloudyrock/mongock/issues/195


推荐阅读