mongos连接池耗尽表现为应用端connection refused或timeout,但mongos自身资源正常;其根本原因是客户端连接数×shard数导致后端连接爆炸,因mongos为每次请求涉及的每个shard单独建连,且无硬性连接限制。mongos 连接池耗尽的典型症状应用端报 connection refused 或 timeout waiting for connection,但 mongos 进程本身 CPU 和内存正常;用 db.currentOp() 查不到大量慢操作;netstat -an | grep :27017 | wc -l 显示 mongos 到后端 shard 的连接数远超预期------比如客户端只开 50 个连接,mongos 却维持了 800+ 到各 shard 的连接。为什么客户端连接数 × shard 数 = mongos 实际连接爆炸mongos 不复用连接:每个客户端连接在路由时,会为**本次请求涉及的每个 shard**(哪怕只查一个 collection)单独建立或复用一条到该 shard 的连接。如果集群有 8 个 shard,客户端开了 100 个连接,极端情况下 mongos 可能撑起近 800 条后端连接(尤其跨分片查询、chunk 迁移期间)。maxPoolSize 在 driver 层控制客户端到 mongos 的连接上限,但它对 mongos 内部到 shard 的连接完全无效mongos 自身没有类似 maxConnPerHost 的硬限制,只靠 connPoolMaxSize(默认 1000)软控,超限后新请求会被阻塞或失败分片键设计不合理(如全表扫描、范围查询覆盖多数 chunk)会加剧连接分散快速缓解:从 mongos 配置和 driver 参数双端压降不是调大连接数,而是减少"连接乘数"的触发条件。 Mokker AI AI产品图添加背景
相关推荐
Li emily3 小时前
解决了加密货币api多币种订阅时的数据乱序问题Dicky-_-zhang4 小时前
消息队列Kafka/RocketMQ选型与高可用架构:从单体到100万TPS的演进2301_781571424 小时前
Golang格式化输出占位符都有什么_Golang fmt占位符教程【通俗】养肥胖虎4 小时前
RAG学习笔记(3):区分数据库检索与RAG的使用场景asdzx674 小时前
使用 Python 为 PDF 添加页码 (详细教程)AI技术控4 小时前
《Transformers are Inherently Succinct》论文解读:从“能表达什么”到“多紧凑地表达”_ku_ku_4 小时前
数据库系统原理 · 数据库应用开发 · 自学总结No8g攻城狮5 小时前
【人大金仓】wsl2+ubuntu22.04安装人大金仓数据库V9山峰哥5 小时前
SQL慢查询调优实战:从全表扫描到索引覆盖的完整复盘代码中介商6 小时前
Redis入门:5大数据类型全解析