rs.reconfig报"Quorum check failed"等错误的直接原因是配置中host不可达或旧IP残留导致仲裁失败;须确保端口连通、版本递增、优先更新配置再操作,并同步DNS、驱动缓存与防火墙。rs.reconfig 报错 "Quorum check failed" 或 "Node not reachable"直接原因:新配置里某个 host 地址不可达,或旧节点还在用原IP尝试通信,导致多数派无法形成。MongoDB 不会自动探测网络连通性,它只按 members[n].host 字段发起连接,失败就卡在投票阶段。实操建议:先确保所有节点(包括要下线的旧IP节点)能用新IP互相 telnet 通 27017 端口------不是 ping,是端口连通性临时把变更节点设为 priority: 0 和 votes: 0,避免它参与选举干扰仲裁用 rs.status() 确认当前 config version 和 term,新配置的 version 必须比当前大 1,term 不能降级不要在 primary 上直接改自己的 host;先把它降为 secondary(rs.stepDown()),再 reconfig修改 members[n].host 后 rs.reconfig 被拒绝:"replSetReconfig old config version too old"本质是配置版本冲突:你读出来的旧配置已被其他节点更新过,rs.reconfig() 要求原子性,不允许基于过期快照覆盖。实操建议:每次操作前都重新执行 rs.conf() 拿最新配置,别复用之前存的变量编辑时只改目标节点的 host 字段,不动 _id、votes、priority 等其他字段(除非你明确要调)如果集群有隐藏节点或延迟节点,它们也必须出现在新配置里,哪怕只是 host 更新了------遗漏会导致校验失败用 rs.reconfig(newConf, {force: true}) 是危险操作,仅当 primary 已彻底失联且你确认其他节点数据一致时才考虑变更后 secondary 启动报错 "No host described in new configuration X for replica set Y"这是启动时加载的 mongod.conf 里 replication.replSetName 和实际配置中 _id 不匹配,或者该节点没被包含在新 members 数组里。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
m0_470857641 小时前
如何制作并发布自己的phpMyAdmin主题_主题结构解析与打包分享的开发者指南2303_821287381 小时前
怎么在MongoDB中追踪一个Document的具体流转路径_从Chunk分布到迁移历史日志分析测试员周周1 小时前
【Appium 系列】第08节-pytest 集成 — conftest.py 中的 fixture 与 hookSunnyDays10111 小时前
如何使用 Python 删除 Word 文档密码和保护重生之小比特1 小时前
【MySQL 数据库】视图weixin_459753941 小时前
mysql如何批量重置数据库用户密码_MySQL批量修改密码Shell脚本人道领域1 小时前
【LeetCode刷题日记】递归与回溯实战 257.二叉树的所有路径——一篇文章彻底搞懂回溯AC赳赳老秦1 小时前
OpenClaw与飞书多维表格联动:自动同步工作数据、生成统计图表,实现高效管理黑贝是条狗1 小时前
注册表破解chrome,edge阻止浏览器连接本地websocket