Spring Boot 项目启动报错:MongoSocketOpenException 连接被拒绝排查日记

1. 背景及环境说明

因为业务需求,引入了一个轻量级的数据库备份组件,组件支持MySQL、MongoDB等数据源的自动数据库备份,而我只需要对MySQL数据库的数据源进行备份,当前我的项目是并没有使用MongoDB的。

引入后启动Spring Boot 项目时,控制台突然出现如下异常:

perl 复制代码
com.mongodb.MongoSocketOpenException: Exception opening socket
Caused by: java.net.ConnectException: Connection refused: connect

令人疑惑的是,项目中并没有配置任何 MongoDB 连接信息,甚至并没有打算使用 MongoDB,但应用启动还是失败了。

2. 排查思路

遇到 Connection refused,直觉是"客户端连接数据库失败",于是按照以下步骤排查:

2.1. 确认当前项目是否使用了MongoDB

先是怀疑了一下我当前跑的这个项目是否其他人加入了MongoDB的使用,只是自己不知情。

检查了 pom.xml 中是否引入 spring-boot-starter-data-mongodb 之类的依赖,但并没有发现。

2.2. 确认 MongoDB 服务是否在运行

这一步我并没有进行,因为我的项目很确定不需要MongoDB,但如果你发现你的项目中是用到的,那就按照下面的排查步骤找一下问题。

① 服务端已启动并监听正确端口:

perl 复制代码
ps -ef | grep mongod
netstat -ano | findstr 27017

② 检查连接地址

Spring Boot 在没有配置时会默认使用 mongodb://localhost:27017。如果服务端不在本地连接会被拒绝。

③ 排查防火墙

如果 MongoDB 部署在远程服务器,在服务器端需要将开放 27017 端口,并在 mongod.conf 中允许外部访问。

2.3. 排查结果

① 项目中没有配置任何MongoDB连接;

pom.xml也没有引入spring-boot-starter-data-mongodb

3. 解决方案

3.1. 找到问题

使用IDEA中Maven Helper等插件,查看自己引入的依赖中是否关联依赖了MongoDB的相关依赖。

根据排查确实在刚用到的tworice-backup-starter依赖中依赖了mongodb-driver-sync,该依赖是为了支持能够从MongoDB数据库中读取并备份数据。

Spring Boot 的自动装配遵循"类路径条件 + 配置属性"原则。

只要以下两个条件满足,就会加载 MongoAutoConfiguration:

类路径上存在 com.mongodb.client.MongoClient,而在我的项目中这一类由官方驱动 mongodb-driver-sync 提供。

Spring Data MongoDB 自动配置类可用

spring-boot-autoconfigureMongoAutoConfiguration会自动扫描。

也就是说,并不需要显式依赖 spring-boot-starter-data-mongodb,只要引入了官方驱动,Spring Boot 仍然认为你要用 MongoDB,并且会:

创建 MongoClient Bean

默认连接 mongodb://localhost:27017

如果本地没有 MongoDB 服务,启动阶段就抛出 MongoSocketOpenException

3.2. 解决问题

我这里只是想使用MongoClient相关类,但不希望Spring Boot自动创建连接,所以在application.yml配置文件中禁用自动配置:

yaml 复制代码
spring:
  autoconfigure:
    exclude: 
      - org.springframework.boot.autoconfigure.mongo.MongoAutoConfiguration
      - org.springframework.boot.autoconfigure.mongo.MongoDataAutoConfiguration

或在主启动类上加注解排除配置类:

ruby 复制代码
@SpringBootApplication(
    exclude = {
        MongoAutoConfiguration.class,
        MongoDataAutoConfiguration.class
    }
)
public class Application { ... }

4. 总结

症状 :仅引入mongodb-driver-sync依赖也会在Spring Boot启动时自动连接MongoDB,若未启动数据库则报 Connection refused

原因 :Spring Boot自动装配只要检测到类路径存在 com.mongodb.client.MongoClient,就触发 MongoAutoConfiguration

解决 :不需要自动配置时,使用 spring.autoconfigure.exclude@SpringBootApplication(exclude = ...) 禁用。

相关推荐
冰暮流星23 分钟前
flask之app.py讲解
后端·python·flask
程序员契奇1 小时前
Tools工具使用
人工智能·后端
IT_陈寒1 小时前
SpringBoot自动配置没生效?你可能漏了这个注解
前端·人工智能·后端
长明1 小时前
C#项目组织与概念梳理
后端·c#
xn71331 小时前
个人网站站外分发怎么做归因?我给 XBSTACK 补了一套 UTM 追踪规则
后端·低代码
用户2330713074791 小时前
JUC 并发容器与工具
后端
冰暮流星2 小时前
flask之模版渲染
后端·python·flask
威武的花瓣2 小时前
细说ASP.NET的各种异步操作
后端·asp.net·php
漂亮的摩托2 小时前
如何编写一个SpringBoot项目告警推送的Starter
java·spring boot·后端
任性的芝麻2 小时前
ASP.NET MVC 中的异步方式
后端·asp.net·mvc