您的位置:首页 > 数据库 > Mongodb

mongodb--replication复制集快速学习

2018-03-11 22:41 246 查看
在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端口成为了主节点。

    


    结束,下次见。

    
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: