You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

Spring Data MongoDB(响应式)整合Spring Boot启动两次问题求助

解决Spring Data MongoDB响应式与WebFlux配合时的重复初始化问题

从你的日志来看,确实出现了两次Spring Data仓库扫描两次MongoDB集群初始化的异常情况——第一次扫描到8个仓库(这应该是你的响应式Mongo仓库),第二次扫描到0个,同时还创建了两种不同模式的Mongo集群(SINGLE和MULTIPLE)。这种问题通常是因为Spring Boot同时加载了普通MongoDB自动配置响应式MongoDB自动配置,导致上下文重复初始化。

下面是具体的排查和解决步骤:

1. 排除普通MongoDB自动配置类

在你的主启动类上,显式排除普通Mongo的自动配置,只保留响应式相关配置:

@SpringBootApplication(
    exclude = {
        MongoAutoConfiguration.class,
        MongoRepositoriesAutoConfiguration.class
    }
)
@EnableReactiveMongoRepositories(basePackages = "com.yourpackage.repository") // 替换为你的实际仓库包路径
public class YourApplication {
    public static void main(String[] args) {
        SpringApplication.run(YourApplication.class, args);
    }
}

这样可以强制Spring只加载响应式Mongo相关的配置,避免普通Mongo配置触发第二次扫描和客户端初始化。

2. 检查依赖是否存在冲突

虽然你使用了spring-boot-starter-data-mongodb-reactive,但有些依赖可能会间接引入普通的spring-boot-starter-data-mongodb。你可以通过Gradle命令查看依赖树:

./gradlew dependencies

如果发现有普通Mongo依赖,在Reactive starter中排除它:

implementation("org.springframework.boot:spring-boot-starter-data-mongodb-reactive") {
    exclude group: 'org.springframework.boot', module: 'spring-boot-starter-data-mongodb'
}

3. 确认仓库接口类型

确保你的所有Mongo仓库接口都继承自ReactiveMongoRepository,而不是普通的MongoRepository。比如:

public interface UserRepository extends ReactiveMongoRepository<User, String> {
    // 自定义业务方法
}

这样能保证响应式配置正确识别你的仓库,避免普通配置扫描时找不到对应类型的仓库(也就是日志中"Found 0 repository interfaces"的原因)。

4. 检查是否存在多上下文初始化

确认你的代码中没有重复触发Spring上下文初始化的逻辑——比如主方法中多次调用SpringApplication.run,或者其他配置类中手动创建ApplicationContext实例。

完成以上步骤后,重新启动应用,应该就能看到只有一次仓库扫描(找到8个仓库)和一次Mongo集群初始化的日志了。

内容的提问来源于stack exchange,提问作者Peter

火山引擎 最新活动