首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > 其他数据库 >

MongoDB 抄本集replSet 配置与分析

2013-10-08 
MongoDB 副本集replSet 配置与分析2个Standard节点1个Arbiter节点 搭建MongoDB Replication Sets创建目录[

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);
MongoDB 抄本集replSet 配置与分析
/Apps/mongo/bin/mongo --port 28010/Apps/mongo/bin/mongo --port 28011/Apps/mongo/bin/mongo --port 28012
//向PRIMARY写入一条数据MongoDB 抄本集replSet 配置与分析

//SECONDARY不能写,而设置slaveOk后,可能从SECONDARY读取数据MongoDB 抄本集replSet 配置与分析
默认情况下SECONDARY不能读写,要设定db.getMongo().setSlaveOk();才可以从SECONDARY读取replSet里只能有一个Primary库,只能从Primary写数据,不能向SECONDARY写数据
//ARBITER 读取写入都不能MongoDB 抄本集replSet 配置与分析
注意arbiter仲裁节点只投票,不接收复制的数据!,不接收PRIMARY写入的mydb的数据!


MongoDB 抄本集replSet 配置与分析从ARBITER节点看到, ARBITER 只存放了local.system.replset里的副本集的配置信息,没有oplog.rs,而ARBITER 也没有接收PRIMARY写入的mydb的数据!说明ARBITER"仅仅起投票作用,而不接收复制的数据"!
MongoDB 抄本集replSet 配置与分析
看看PRIMARY的local.slaves,看到只有一个slave(而不是两个),这个slave就是SECONDARY节点,这里ARBITER节点不是PRIMARY的slave,这也说明ARBITER"仅仅起投票作用,而不接收复制的数据"!

故障切换测试:
Ctrl+C退出PRIMARY进程, PRIMARY节点28010就DOWN了,

看看原来的SECONDARY(28011)节点,MongoDB 抄本集replSet 配置与分析
再看看ARBITER节点(28012)MongoDB 抄本集replSet 配置与分析
PRIMARY节点28010 DOWN了之后, ARBITER就投票给SECONDARY 28011, SECONDARY 就成为新的PRIMARY节点
MongoDB 抄本集replSet 配置与分析
总结:1:当副本集的总可投票数为偶数时,可能出现无法选举出主节点的情况,mongod会提示:MongoDB 抄本集replSet 配置与分析
2个Standard节点组成Replication Sets是不合理的,因为不具备故障切换能力!
A:当SECONDARY Down掉,剩下一个PRIMARY,此时副本集运行不会出问题,因为不用选择PRIMARY节点B:当PRIMARY Down掉,此时副本集只剩下一个SECONDARY,它只有1票,不超过总节点数的半数,它不会选举自己为PRIMARY节点!
提示如下:
MongoDB 抄本集replSet 配置与分析



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同样可以服务MongoDB 抄本集replSet 配置与分析

热点排行