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端口成为了主节点。

    

    结束,下次见。

    


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值