mongodb--replication复制集快速学习
在Mongo中,如果只有一份数据集,万一出现某些意外,那么数据将会出现损坏或丢失。为了解决这个问题,Mongo提供了复制集,来抵抗这种数据丢失的风险。
什么是复制集呢?复制集(replication)就是多台服务器维护相同的数据副本,以提高服务器的可用性。复制集分为一个主数据集(primary),和多个从数据集(secondary)。以2个从数据集为例,来说明主从数据集之间的关系。如下图:
主从数据集之间可以相互通信,用以确保服务器的可用性。
那么如何创建数据集呢?下面我们以win7(32位)操作系统为例,来说明创建步骤。
一、启动3个mongo进程,分别指定不同的端口(27017,27018,27019)。
命令的格式为:mongod --port xxxx --dbpath xxxxx --logpath xxxxxx --storageEngine mmapv1 --replSet rs2 (复制集的名字为rs2,32位机器需要指定--storageEngine mmapv1,64位不需要)。
(27017端口,可不加port选项)
(27018端口)
(27019端口)
二、启动mongo,切换到admin数据库并进行复制集的初始化配置
在shell中,输入mongo,然后切换到admin数据库;
编写配置文件:
var rsconf={
_id:'rs2',
members:[
{
_id:0,
host:'192.168.1.100:27017'
},
{
_id:1,
host:'192.168.1.100:27018'
},
{
_id:2,
host:'192.168.1.100:27019'
}
]
}
然后进行初始化:rs.initiate(rsconf);
查看复制集状态:rs.status();
可以看到,此时已经把复制集创建好了。
三、更改从数据集的设置、添加或移除复制集。
在cmd窗口中通过:mongo --port 27018 进入第一个从节点中,然后输入命令rs.slaveOk(),此时就可以读写从数据集了(默认为不读也不写)。
还可以通过rs.add,rs.remove进行添加或移除节点。参数为节点所在位置及端口。
在主数据集中添加一条数据,如下图
然后我们在从数据集中查看,
可以看到,从数据集中数据与主数据集中保持了一致。
当主节点出现问题时,Mongo会自动更换其中一个从节点变为主节点。如图
然后rs.status(),可以看到27019端口成为了主节点。
结束,下次见。