MongoDB 副本集replSet 配置与分析

2个Standard节点+1个Arbiter节点 搭建MongoDB Replication Sets

创建目录
[root@localhost ~]# mkdir -p /data/replset/r0
[root@localhost ~]# mkdir -p /data/replset/r1
[root@localhost ~]# mkdir -p /data/replset/r2
[root@localhost ~]# mkdir -p /data/replset/key
[root@localhost ~]# mkdir -p /data/replset/log


创建KEY
[root@localhost ~]# echo "replset1 key" > /data/replset/key/r0
[root@localhost ~]# echo "replset1 key" > /data/replset/key/r1
[root@localhost ~]# echo "replset1 key" > /data/replset/key/r2
[root@localhost ~]# chmod 600 /data/replset/key/r*  //600,防止其它程序改写此KEY


/Apps/mongo/bin/mongod --dbpath=/data/replset/r0 --replSet replset1 --keyFile /data/replset/key/r0 --port 28010

/Apps/mongo/bin/mongod --dbpath=/data/replset/r1 --replSet replset1 --keyFile /data/replset/key/r1 --port 28011

/Apps/mongo/bin/mongod --dbpath=/data/replset/r2 --replSet replset1 --keyFile /data/replset/key/r2 --port 28012

注:--keyFile /data/key/r0 加了这个后,MongVUE就连不到了



改用下面的就行了(这是里为方便看日志,直接在命令行输出查看)

/Apps/mongo/bin/mongod --dbpath=/data/replset/r0 --replSet  replset1 --port 28010 --directoryperdb

/Apps/mongo/bin/mongod --dbpath=/data/replset/r1 --replSet  replset1 --port 28011 --directoryperdb

/Apps/mongo/bin/mongod --dbpath=/data/replset/r2 --replSet  replset1 --port 28012 --directoryperdb


正式运行要后台运行就用下面的:

/Apps/mongo/bin/mongod --dbpath=/data/replset/r0 --replSet  replset1  --port 28010 --logpath=/data/replset/log/r0.log --logappend --fork --directoryperdb

/Apps/mongo/bin/mongod --dbpath=/data/replset/r1 --replSet  replset1  --port 28011 --logpath=/data/replset/log/r1.log --logappend --fork --directoryperdb

/Apps/mongo/bin/mongod --dbpath=/data/replset/r2 --replSet  replset1  --port 28012 --logpath=/data/replset/log/r2.log --logappend --fork --directoryperdb



初始化复本集:

/Apps/mongo/bin/mongo --port 28010

config_replset1 = {
_id:"replset1",
members:
[
{_id:0,host:"127.0.0.1:28010",priority:4},
{_id:1,host:"127.0.0.1:28011",priority:2},
{_id:2,host:"127.0.0.1:28012",arbiterOnly : true}
]
}

注意arbiter仲裁节点只投票,不接收复制的数据!



rs.initiate(config_replset1);


/Apps/mongo/bin/mongo --port 28010
/Apps/mongo/bin/mongo --port 28011
/Apps/mongo/bin/mongo --port 28012

//向PRIMARY写入一条数据


//SECONDARY不能写,而设置slaveOk后,可能从SECONDARY读取数据

默认情况下SECONDARY不能读写,要设定db.getMongo().setSlaveOk();才可以从SECONDARY读取
replSet里只能有一个Primary库,只能从Primary写数据,不能向SECONDARY写数据

//ARBITER 读取写入都不能

注意arbiter仲裁节点只投票,不接收复制的数据!,不接收PRIMARY写入的mydb的数据!



从ARBITER节点看到, ARBITER 只存放了local.system.replset里的副本集的配置信息,没有oplog.rs,
而ARBITER 也没有接收PRIMARY写入的mydb的数据!说明 ARBITER"仅仅起投票作用,而不接收复制的数据"!


看看PRIMARY的local.slaves,看到只有一个slave(而不是两个),这个slave就是SECONDARY节点,这里ARBITER节点不是PRIMARY的slave,
这也说明ARBITER"仅仅起投票作用,而不接收复制的数据"!


故障切换测试:

Ctrl+C退出 PRIMARY进程, PRIMARY节点28010就DOWN了,


看看原来的 SECONDARY(28011)节点,

再看看 ARBITER节点(28012)

PRIMARY节点28010 DOWN了之后, ARBITER就投票给SECONDARY 28011, SECONDARY 就成为新的PRIMARY节点


总结:
1:当副本集的总可投票数为偶数时,可能出现无法选举出主节点的情况,mongod会提示:

2个Standard节点组成Replication Sets是不合理的,因为不具备故障切换能力!

A:当SECONDARY Down掉,剩下一个PRIMARY,此时副本集运行不会出问题,因为不用选择PRIMARY节点
B:当PRIMARY Down掉,此时副本集只剩下一个SECONDARY,它只有1票,不超过总节点数的半数,它不会选举自己为PRIMARY节点!

提示如下:





3个Standard节点组成Replication Sets是可以的,当PRIMARY节点DOWN了还是可以再选出一个PRIMARY节点,此时要马上修复DOWN机的节点,
因为不修复的话如果当前的PRIMARY节点再DOWN了,剩下一个SECONDARY节点是不能选出PRIMARY节点的!

可行方案: 3个Standard节点 或 2个Standard节点+1个Arbiter节点

个人感觉如果只有2台服务器,可以将优先级高的Standard部署到1台高性能的服务器,
然后将另一个Standard节点+1个Arbiter节点部署到另一台服务器,
这样 PRIMARY节点在1台服务器, SECONDARY结点和 ARBITER节点和另一台服务器,
这样无论哪个节点坏了,ReplSet同样可以服务

  • 6
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值