当前位置: 首页 > news >正文

Spring Boot MongoDB自定义连接池配置

手打不易,如果转摘,请注明出处!

注明原文:http://zhangxiaofan.blog.csdn.net/article/details/144341407


一、引言

在 Spring Boot 应用中使用 MongoDB 时,合理配置连接池可以显著提升数据库访问的性能和稳定性。默认情况下,Spring Data MongoDB 会使用 MongoDB Java 驱动的默认连接池配置,但在生产环境中,我们通常需要根据业务需求自定义参数(如最大连接数、超时时间等)。本文将详细介绍如何在 Spring Boot 中自定义 MongoDB 连接池,适合新手快速上手。

二、环境准备

技术版本

  • Spring Boot 2.x.x
  • MongoDB 3.x(Spring Data MongoDB 自动依赖)
  • MongoDB 服务(本地或远程,版本 >= 4.0)

 依赖配置

在 pom.xml 中添加 MongoDB 依赖(Spring Boot 起步依赖会自动包含驱动):

<dependency>  
    <groupId>org.springframework.boot</groupId>  
    <artifactId>spring-boot-starter-data-mongodb</artifactId>  
</dependency>  

 三、核心参数

1. 连接池大小参数

参数名作用推荐值(生产环境)
maxConnectionPoolSize单个主机的最大连接数,超过时请求排队根据业务并发量调整,一般 50-200
minConnectionPoolSize保持的最小空闲连接数,减少新建连接开销5-20(视访问频率)

2. 超时参数

参数名作用推荐值
connectTimeoutMS建立连接的超时时间10-30 秒
socketTimeoutMS读写数据的超时时间(0 表示不超时)30-60 秒
serverSelectionTimeoutMS选择可用服务器的超时(如副本集切换)5-15 秒

四、配置连接池

1.properties配置

# application.yml示例  
spring:  
  data:  
    mongodb:  
      uri: mongodb://username:password@localhost:27017/databaseName  
      # 连接池参数  
      connection-timeout: 5000  # 连接超时时间(毫秒)  
      max-wait-time: 1000       # 等待连接的最大时间(毫秒)  
      max-inactive: 60000       # 连接空闲超时时间(毫秒)  
      max-size: 50              # 最大连接数  
      min-size: 10              # 最小连接数  
      threads-allowed-to-block-multiplier: 5  # 允许阻塞的线程数乘数  

2.连接串配置

spring.data.mongodb.uri=mongodb://user:password@host:port/database?maxPoolSize=50&minPoolSize=5&connectTimeoutMS=15000&socketTimeoutMS=30000&serverSelectionTimeoutMS=20000  


3.Java代码配置

import com.mongodb.ConnectionString;  
import com.mongodb.MongoClientSettings;  
import com.mongodb.client.MongoClient;  
import com.mongodb.client.MongoClients;  
import org.springframework.context.annotation.Bean;  
import org.springframework.context.annotation.Configuration;  
import org.springframework.data.mongodb.config.AbstractMongoClientConfiguration;  

@Configuration  
public class MongoConfig extends AbstractMongoClientConfiguration {  

    private final String databaseName = "your_database";  
    private final String connectionUri = "mongodb://host:port";  

    @Override  
    protected String getDatabaseName() {  
        return databaseName;  
    }  

    @Override  
    @Bean  
    public MongoClient mongoClient() {  
        // 解析连接字符串  
        ConnectionString connectionString = new ConnectionString(connectionUri);  
        // 构建连接池配置  
        MongoClientSettings settings = MongoClientSettings.builder()  
            .applyConnectionString(connectionString)  
            // 自定义连接池参数  
            .maxConnectionPoolSize(50)          // 最大连接数  
            .minConnectionPoolSize(5)           // 最小空闲连接数  
            .connectTimeout(Duration.ofMillis(15000))  // 连接超时  
            .socketTimeout(Duration.ofMillis(30000))   // 套接字超时  
            .serverSelectionTimeout(Duration.ofMillis(20000)) // 服务器选择超时  
            // 其他配置:SSL、认证、负载均衡策略等  
            .sslEnabled(false)                   // 是否启用 SSL  
            .build();  
        return MongoClients.create(settings);  
    }  
}  

五、查看是否生效

六、实践建议

  • 生产环境建议通过JVM监控工具(如Prometheus+Grafana)持续跟踪连接池状态。
  • 根据业务流量波动,动态调整连接池参数(如高峰期增大max-size
  • 根据业务需求调整参数:不同的业务场景对连接池的需求不同,需要根据实际负载进行调整。

  • 监控连接池状态:使用监控工具(如 MongoDB 自带的监控工具)来观察连接池的使用情况,及时发现潜在问题。

  • 避免连接泄漏:确保在代码中正确关闭数据库连接,避免连接泄漏导致连接池耗尽。

  • 定期测试和优化:定期对连接池配置进行测试和优化,确保其始终处于最佳状态。

http://www.dtcms.com/a/123264.html

相关文章:

  • 十分钟机器学习之--------------线性回归
  • 关于 Spring Boot 后端项目使用 Maven 打包命令、JAR/WAR 对比、内嵌服务器与第三方服务器对比,以及热部署配置的详细说明
  • 雷池WAF身份认证 - CAS
  • 数码视讯TR100系列/TR100-G1/TR100-G4/数码视讯F7-国科GK6323V100C芯片-刷机固件包
  • 如何优雅使用 ReentrantLock 进行加解锁:避免常见坑点,提高代码可维护性
  • ADI的BF561双核DSP怎么做开发,我来说一说(十一)NANDFLASH的读写
  • 十三届蓝桥杯Java省赛 B组(持续更新..)
  • YOLO 8 入坑(持续更新)
  • 【含文档+PPT+源码】基于Android家政服务系统的开发与实现
  • 【python】yield关键字的使用及执行步骤分析
  • HTTP 1.0 时代,第一次优化
  • antv x6使用(支持节点排序、新增节点、编辑节点、删除节点、选中节点)
  • ThinkpPHP生成二维码
  • 【C++初阶】--- vector容器功能模拟实现
  • STM32硬件IIC+DMA驱动OLED显示——释放CPU资源,提升实时性
  • Keras简介
  • AI 赋能 DBA:如何用 DeepSeek 等大模型简化数据库管理工作
  • 【每日随笔】丛林法则 ( 弱肉强食 | 适者生存 | 资源有限稀缺 | 没有道德约束 | 自发性与无序性 | 丛林法则映射 - 资源分配 与 社会分层 )
  • C++23新特性:显式对象形参与显式对象成员函数
  • Unity AssetBundle依赖树可视化分析工具开发指南
  • BeagleBone Black笔记
  • 传感器篇(二)——激光雷达
  • Prompt-to-prompt image editing with cross attention control
  • 网络通讯协议UDP转发TCP工具_UdpToTcpRelay_双向版
  • 蓝桥杯c ++笔记(含算法 贪心+动态规划+dp+进制转化+便利等)
  • 食堂采购系统源码模块化开发详解:管理、订单、入库、对账一体化方案
  • 游戏引擎学习第214天
  • module错误集合
  • SAP Business One系统标准功能之外的不允许负库存控制
  • 使用 react-three-fiber 快速重构 Three.js 场景⚛️