今天我测试了一下MongoDB的副本集的配置。
首先从概念上说一下MongoDB副本集和主从复制的区别。其实副本集(Replica Set)是主从复制的高级形式。高级在哪里呢?主动复制实现了数据备份+读扩展,但是master一旦down掉,需要手动启动slave。副本集在此基础上实现了备份自动重启的功能,也就是某一台slave会挺身而出,担当起master的职责。所以有三个角色,master(Primary),slave(Secondary),还有仲裁服务器。
我的测试环境和上次基本相同:
一台master(primary):mmaster 192.168.42.132
两台slave(secondary):mslave1 192.168.42.134 mslave2 192.168.42.135
全是ubuntu 12.10 server 版 OS, MongoDB 2.4.3
配置和实现方法:
1 配置/etc/hosts,把上面三台虚拟机的DNS信息写到里面
2 配置/etc/mongodb.conf,需要修改的东西真是不多,最主要的是屏蔽掉master slave这部分东西,也就是主从复制里面的修改,然后配置replSet=true,有没有空格无所谓,三台虚拟机都只这么配置,可见我们并没有指定谁是master。
3 先把master跑起来。进入你想成为master的那台机器,重启mongod,然后进入该机器mongo的客户端,进行一下很简单的设置。