MongoDB副本集部署(windows)

环境准备

本教程演示mongodb4.4 副本集部署(一主两从,伪分布式)

节点 配置
主节点 localhost:27017
从节点1 localhost:27018
从节点2 localhost:27019

每一个节点(实例)都创建对应的数据文件(data)和日志文件(log)。例如:

启动实例(服务)

语法:

复制代码
bin>mongod -port 端口号  -dbpath 数据路径 -logpath 日志路径 -replSet 副本集名称

示例:

复制代码
>mongod -port 27018 -dbpath D:\MongoDB1\data -logpath D:\MongoDB1\log\mongo1.log -replSet rs0

主节点:

从节点1(以管理员身份启动):

从节点2:

以上三个节点启动的都是一次性服务,所以窗口不要关闭!

tips:

节点启动可能会遇到问题,主要检查端口是否被占用,和路径配置问题。若都没问题则考虑以管理员身份启动cmd。

配置副本集

维持服务不要关闭,进入任何一个节点内:

进行配置:

1.切换到admin数据库

复制代码
use admin

2.配置集群

复制代码
config={_id:"rs0",members:[
... {_id:0,host:"localhost:27017","priority":3},
... {_id:1,host:"localhost:27018","priority":2},
... {_id:2,host:"localhost:27019","priority":1}]}

说明:第一个"_id"为副本集名称,"priority"为优先级,数字越大,优先级越高。

3.使得配置生效

复制代码
rs.initiate(config)

生效后可能会出现节点显示错误:

(明明是主节点,但却显示从节点)

只需要查看副本集状态即可更正:

复制代码
 rs.status()


从节点配置

刚刚配置好的副本集中的从节点是无法进行数据库操作的:

要先进行从节点永久化设置:

复制代码
rs.slaveOk()

或者使用(推荐使用):

复制代码
rs.secondaryOk() 

副本集验证

在主节点中增加数据

在从节点上验证:

说明副本集群部署成功。

相关推荐
星星点点洲32 分钟前
【缓存与数据库结合最终方案】伪从技术
数据库·缓存
小黑屋的黑小子34 分钟前
【MySQL】MySQL索引与事务
数据库·mysql·oracle
Clank的游戏栈2 小时前
Unity多线程渲染指令队列设计与集成技术详解
windows·unity·游戏引擎
OK_boom3 小时前
Dapper的数据库操作备忘
数据库
艺杯羹4 小时前
JDBC之ORM思想及SQL注入
数据库·sql·jdbc·orm·sql注入
blackA_4 小时前
数据库MySQL学习——day4(更多查询操作与更新数据)
数据库·学习·mysql
极限实验室5 小时前
Easysearch 迁移数据之 Reindex From Remote
数据库
朴拙数科5 小时前
基于LangChain与Neo4j构建企业关系图谱的金融风控实施方案,结合工商数据、供应链记录及舆情数据,实现隐性关联识别与动态风险评估
数据库·langchain·neo4j
小李学不完6 小时前
Oracle--SQL事务操作与管理流程
数据库
qq_441996056 小时前
为何 RAG 向量存储应优先考虑 PostgreSQL + pgvector 而非 MySQL?
数据库·mysql·postgresql