1、概述

复制集是一个带有故障转移的主从集群。是从现有的主从模式演变而来,增加了自动故障转移和节点成员自动恢复。

复制集模式中没有固定的主结点,在启动后,多个服务节点间将自动选举 产生一个主结点。该主结点被称为primary,一个或多个从结点被称为secondaries。primary结点基本上就是master结点,不同之 处在于primary结点在不同时间可能是不同的服务器。如果当前的主结点失效了,复制集中的其余结点将会试图选出一个新的主结点。

复制集模式的好处是,一切自动化。首先,复制集模式本身做了大量的管理工作,自动管理从节点,确保数据不会不一致。其次,主节点挂掉后,会自动判断集群中的服务器并进行故障转移,推举新的主节点。

一个复制集集群支持1-7台服务器,在一个复制集中各个服务器数据保持完全一致。

在一个复制集集群中,各个服务器有以下几种状态:

  1. Primary 主节点,一个复制集有且仅有一台服务器处于Primary状态,只有主节点才对外提供读写服务。如果主节点挂掉,复制集将会投票选出一个备用节点成为新的主节点。
  2. Secondary 备用节点,复制集允许有多台Secondary,每个备用节点的数据与主节点的数据是完全同步的。
  3. Recovering 恢复中,当复制集中某台服务器挂掉或者掉线后数据无法同步,重新恢复服务后从其他成员复制数据,这时就处于恢复过程,数据同步后,该节点又回到备用状态。
  4. Arbiter 仲裁节点,该类节点可以不用单独存在,如果配置为仲裁节点,就主要负责在复本集中监控其他节点状态,投票选出主节点。该节点将不会用于存放数据。如果没有仲裁节点,那么投票工作将由所有节点共同进行。
  5. Down 无效节点,当服务器挂掉或掉线时就会处于该状态。

复制集的从节点读请求,也是在各个Driver层设置slaveOk的值来实现的。

2、示例

  • 创建一个包含三个服务器的mongodb 的副本集   (不要把 --auth 开启了 不然会使得 复本集之间无法通信)
/usr/local/mongodb/mongod -dbpath=/data/mongodbreplset/ --fork --port  --logpath=/usr/local/mongodb/log/mongodbreplset/m19.log --logappend --replSet rsdemo --smallfiles

/usr/local/mongodb/mongod -dbpath=/data/mongodbreplset/ --fork --port  --logpath=/usr/local/mongodb/log/mongodbreplset/m18.log --logappend --replSet rsdemo --smallfiles

/usr/local/mongodb/mongod -dbpath=/data/mongodbreplset/ --fork --port  --logpath=/usr/local/mongodb/log/mongodbreplset/m17.log --logappend --replSet rsdemo --smallfiles
  • 执行以下操作 初始化复制集
rsdemo:PRIMARY> var rsconf={
... _id:'rsdemo',
... members:[
... {_id:,host:'192.168.0.108:27017'},
... {_id:,host:'192.168.0.108:27018'},
... {_id:,host:'192.168.0.108:27019'}
... ]}
rsdemo:PRIMARY> rs.reconfig(rs)
rs( rsconf
rsdemo:PRIMARY> rs.reconfig(rsconf) //rs.initiate(rsconf)
{ "ok" : }
  • 查看复制集合的状态:rs.status()
rsdemo:PRIMARY> rs.status()
{
"set" : "rsdemo",
"date" : ISODate("2015-11-16T14:19:12Z"),
"myState" : ,
"members" : [
{
"_id" : ,
"name" : "192.168.0.108:27017",
"health" : ,
"state" : ,
"stateStr" : "SECONDARY",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("2015-11-16T14:19:06Z"),
"lastHeartbeat" : ISODate("2015-11-16T14:19:10Z"),
"lastHeartbeatRecv" : ISODate("2015-11-16T14:19:11Z"),
"pingMs" : ,
"syncingTo" : "192.168.0.108:27019"
},
{
"_id" : ,
"name" : "192.168.0.108:27018",
"health" : ,
"state" : ,
"stateStr" : "SECONDARY",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("2015-11-16T14:19:06Z"),
"lastHeartbeat" : ISODate("2015-11-16T14:19:11Z"),
"lastHeartbeatRecv" : ISODate("2015-11-16T14:19:11Z"),
"pingMs" : ,
"syncingTo" : "192.168.0.108:27019"
},
{
"_id" : ,
"name" : "192.168.0.108:27019",
"health" : ,
"state" : ,
"stateStr" : "PRIMARY",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("2015-11-16T14:19:06Z"),
"electionTime" : Timestamp(, ),
"electionDate" : ISODate("2015-11-16T14:04:03Z"),
"self" : true
}
],
"ok" :
}
  • 查看配置信息 rs.conf()
rsdemo:PRIMARY> rs.conf()
{
"_id" : "rsdemo",
"version" : ,
"members" : [
{
"_id" : ,
"host" : "192.168.0.108:27017"
},
{
"_id" : ,
"host" : "192.168.0.108:27018"
},
{
"_id" : ,
"host" : "192.168.0.108:27019"
}
]
}
rsdemo:PRIMARY>
  • 查看是不是主节点
rsdemo:PRIMARY> rs.isMaster(
... )
{
"setName" : "rsdemo",
"setVersion" : ,
"ismaster" : true,
"secondary" : false,
"hosts" : [
"192.168.0.108:27019",
"192.168.0.108:27018",
"192.168.0.108:27017"
],
"primary" : "192.168.0.108:27019",
"me" : "192.168.0.108:27019",
"maxBsonObjectSize" : ,
"maxMessageSizeBytes" : ,
"maxWriteBatchSize" : ,
"localTime" : ISODate("2015-11-16T14:51:16.795Z"),
"maxWireVersion" : ,
"minWireVersion" : ,
"ok" :
}
  • 测试复制集合
  1.  首先在主节点创建demo库
  2.  for 循环添加1000条数据
  3.  主库查看是不是存在
  4.  检查副本集成员是不是含有该记录
rsdemo:PRIMARY>  for(var i=;i<;i++){db.demo.insert({count:i})}
WriteResult({ "nInserted" : })
rsdemo:PRIMARY> show dbs
admin (empty)
demo .031GB
local .094GB
rsdemo:PRIMARY> use demo
switched to db demo
rsdemo:PRIMARY> db.demo.find()
{ "_id" : ObjectId("563e24b2a731ac9621c37650"), "age" : , "name" : "赵兴壮" }
{ "_id" : ObjectId("5649e70fff8e3af9408ff52f"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff530"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff531"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff532"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff533"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff534"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff535"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff536"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff537"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff538"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff539"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff53a"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff53b"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff53c"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff53d"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff53e"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff53f"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff540"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff541"), "count" : }
Type "it" for more
rsdemo:SECONDARY> rs.slaveOk()// 注意
rsdemo:SECONDARY> db.demo.find()
{ "_id" : ObjectId("563e24b2a731ac9621c37650"), "age" : , "name" : "赵兴壮" }
{ "_id" : ObjectId("5649e70fff8e3af9408ff52f"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff530"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff531"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff532"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff533"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff534"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff535"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff536"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff537"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff538"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff539"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff53a"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff53b"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff53c"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff53d"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff53e"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff53f"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff540"), "count" : }
{ "_id" : ObjectId("5649e70fff8e3af9408ff541"), "count" : }
Type "it" for more
rsdemo:SECONDARY>

MongoDB 复制集模式Replica Sets的更多相关文章

  1. MongoDB复制集成员及架构介绍(一)

    MongoDB复制集介绍 MongoDB支持在多个机器中通过异步复制达到提供了冗余,增加了数据的可用性.MongoDB有两种类型的复制,第一种是同于MySQL的主从复制模式(MongoDB已不再推荐此 ...

  2. MongoDb复制集实现故障转移,读写分离

    前言 数据库技术是信息系统的一个核心技术,发展很快,各种功能类型数据库层出不穷,之前工作中使用过关系型数据库(mysql.oracle等).面相对象数据库(db4o).key-value存储(Memc ...

  3. mongodb复制集Replica Set使用简介

    MongoDB高可用 对于MongoDB,可以支持使用单机模式提供服务,但是在实际的生产环境中,单机模式将面临很大的风险,一旦这个数据库服务出现问题,就会导致线上的服务出现错误甚至崩溃.因此,在实际生 ...

  4. 关于 MongoDB 复制集

    为什么要使用复制集 1.备份数据通过自带的 mongo_dump/mongo_restore 工具也可以实现备份,但是毕竟没有复制集的自动同步备份方便. 2.故障自动转移部署了复制集,当主节点挂了后, ...

  5. Raft与MongoDB复制集协议比较

    在一文搞懂raft算法一文中,从raft论文出发,详细介绍了raft的工作流程以及对特殊情况的处理.但算法.协议这种偏抽象的东西,仅仅看论文还是比较难以掌握的,需要看看在工业界的具体实现.本文关注Mo ...

  6. MongoDB 复制集 (一) 成员介绍

       一 MongoDB 复制集简介          MongoDB的复制机制主要分为两种:          Master-Slave    (主从复制)      这个已经不建议使用       ...

  7. MongoDB复制集的工作原理介绍(二)

    复制集工作原理 1)数据复制原理 开启复制集后,主节点会在 local 库下生成一个集合叫 oplog.rs,这是一个有限集合,也就是大小是固定的.其中记录的是整个mongod实例一段时间内数据库的所 ...

  8. MongoDB复制集成员及状态转换

    此文已由作者温正湖授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 复制集(Replica Set)是MongoDB核心组件,相比早期版本采用的主从(Master-Slave) ...

  9. MongoDB复制集原理

    版权声明:本文由孔德雨原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/136 来源:腾云阁 https://www.qclo ...

随机推荐

  1. 《University Calculus》-chape10-向量和空间几何学-叉积

    叉积概念的引入: 在平面中我们为了度量一条直线的倾斜状态,为引入倾斜角这个概念.而通过在直角坐标系中建立tan α = k,我们实现了将几何关系和代数关系的衔接,这其实也是用计算机解决几何问题的一个核 ...

  2. hdu 4750 Count The Pairs(并查集)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4750 代码: #include<cstdio> #include<cstring&g ...

  3. svn操作

    1.已经被svn管理的文件的复制.删除.重命名都要通过svn的命令来操作(在资源管理器中通过鼠标右键来完成)(复制粘贴可以通过右键按下移动来实现) 2.没有被svn管理的文件(没有被上传过的文件,没有 ...

  4. 回某位朋友问题备受phpcgi.exe煎熬现在cpu跑满(解决方案)

    (本文原创,但是cgi参数参考一个大神写的针对小服务器的,希望大家积极投票哦) 下面是对php-cgi.ext过多引起服务器cup%的解决方法,希望对大家有帮助;大多数情况是发生在第四项上;   解决 ...

  5. bzoj1827 [Usaco2010 Mar]gather 奶牛大集会

    不就是移一下树根,回溯一下吗? 诶?黄学长为什么可以直接找? 诶?这不是重心吗? YY了一下证明 很简单 由于重心max{sz[v]} <= sz[u] / 2的性质,可以证明每一步远离重心的移 ...

  6. K倍动态减法游戏

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=2580 #include <iostream> #include <string.h> ...

  7. CMake高速入门

    入门基础:http://www.ibm.com/developerworks/cn/linux/l-cn-cmake/       在 linux 下使用 CMake 构建应用程序 入门进阶:http ...

  8. android 28 SimpleAdapter

    监听器返回fasle,则事件还会分发给其他监听器. SimpleAdapter是BaseAdapter的子类,对适配器进行了简化,数据的格式是List,List的元素必须是Map, public Si ...

  9. 高级性能调试手段(oprofile+gprofile)+内核追踪手段:LTT

    http://blog.csdn.net/wlsfling/article/details/5876134http://www.lenky.info/archives/2012/03/1371http ...

  10. MapReduce实战:统计不同工作年限的薪资水平

    1.薪资数据集 我们要写一个薪资统计程序,统计数据来自于互联网招聘hadoop岗位的招聘网站,这些数据是按照记录方式存储的,因此非常适合使用 MapReduce 程序来统计. 2.数据格式 我们使用的 ...