MongoDB Master Slave role switchover

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介:

测试环境:
MASTER(A):
172.16.3.176
/opt/mongodb/bin/mongod --master --config /opt/mongodb/conf/mongodb1.conf --oplogSize=256
config:
[root@db5 data1]# cat /opt/mongodb/conf/mongodb1.conf 
port=5281
fork=true
logpath=/var/log/mongodb1.log
logappend=true
dbpath=/home/mongodb/data1
directoryperdb=true
auth=true
maxConns=1000
nohttpinterface=true
nssize=128

SLAVE(B):
172.16.3.33
/opt/mongodb/bin/mongod --slave --source 172.16.3.176:5281 --config /opt/mongodb/conf/mongodb1.conf
config:
[root@db-172-16-3-33 conf]# cat /opt/mongodb/conf/mongodb1.conf 
port=5281
fork=true
logpath=/var/log/mongodb1.log
logappend=true
dbpath=/opt/mongodb/data1
directoryperdb=true
auth=true
maxConns=1000
nohttpinterface=true
nssize=128

1. Failing over to a Slave (Promotion) 这种情况一般发生在A机器不能访问或已经损坏的情况。不可逆
操作步骤:
1.1 关闭A
1.2 关闭B
1.3 删除B上的local库数据文件
1.4 启动B 带上--master参数

2. Inverting Master and Slave 这种情况一般发生在需要对A机器进行维护,需要把B作为MASTER使用。可以逆转
操作步骤:
2.1 禁止A机库写操作 ( 通过 lock HALT 住些操作 , db.runCommand({fsync:1,lock:1}) )
2.2 确保B机库与A机库完全同步
2.3 关闭B机库
2.4 删除B机库local数据库数据文件
2.5 启动B机器库 带上 --master参数
2.6 B机库上进入local,新建repl用户,密码保持和原来的一样 (假设开启了auth).
2.7 关闭B机库
2.8 关闭A机库,(确保不关闭写LOCK的情况下关库,保证)删除B机库LOCAL数据库文件,拷贝B机库的local数据目录到A机库.
2.9 启动B机器库 带上 --master参数
2.10 启动A机库 带上slave source 再加上   --fastsync  参数.
目录
相关文章
|
NoSQL MongoDB 网络安全
|
NoSQL 数据库 数据安全/隐私保护
|
3月前
|
NoSQL MongoDB 数据库
数据库数据恢复—MongoDB数据库数据恢复案例
MongoDB数据库数据恢复环境: 一台操作系统为Windows Server的虚拟机上部署MongoDB数据库。 MongoDB数据库故障: 工作人员在MongoDB服务仍然开启的情况下将MongoDB数据库文件拷贝到其他分区,数据复制完成后将MongoDB数据库原先所在的分区进行了格式化操作。 结果发现拷贝过去的数据无法使用。管理员又将数据拷贝回原始分区,MongoDB服务仍然无法使用,报错“Windows无法启动MongoDB服务(位于 本地计算机 上)错误1067:进程意外终止。”
|
3月前
|
缓存 NoSQL Linux
在CentOS 7系统中彻底移除MongoDB数据库的步骤
以上步骤完成后,MongoDB应该会从您的CentOS 7系统中被彻底移除。在执行上述操作前,请确保已经备份好所有重要数据以防丢失。这些步骤操作需要一些基本的Linux系统管理知识,若您对某一步骤不是非常清楚,请先进行必要的学习或咨询专业人士。在执行系统级操作时,推荐在实施前创建系统快照或备份,以便在出现问题时能够恢复到原先的状态。
277 79
|
3月前
|
存储 NoSQL MongoDB
MongoDB数据库详解-针对大型分布式项目采用的原因以及基础原理和发展-卓伊凡|贝贝|莉莉
MongoDB数据库详解-针对大型分布式项目采用的原因以及基础原理和发展-卓伊凡|贝贝|莉莉
176 8
MongoDB数据库详解-针对大型分布式项目采用的原因以及基础原理和发展-卓伊凡|贝贝|莉莉
|
2月前
|
运维 NoSQL 容灾
告别运维噩梦:手把手教你将自建 MongoDB 平滑迁移至云数据库
程序员为何逃离自建MongoDB?扩容困难、运维复杂、高可用性差成痛点。阿里云MongoDB提供分钟级扩容、自动诊断与高可用保障,助力企业高效运维、降本增效,实现数据库“无感运维”。
|
6月前
|
NoSQL MongoDB 数据库
数据库数据恢复——MongoDB数据库服务无法启动的数据恢复案例
MongoDB数据库数据恢复环境: 一台Windows Server操作系统虚拟机上部署MongoDB数据库。 MongoDB数据库故障: 管理员在未关闭MongoDB服务的情况下拷贝数据库文件。将MongoDB数据库文件拷贝到其他分区后,对MongoDB数据库所在原分区进行了格式化操作。格式化完成后将数据库文件拷回原分区,并重新启动MongoDB服务。发现服务无法启动并报错。