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同样可以服务