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. Ural 1258 镜面对称

    #include<cstdio> #include<cstring> #include<cmath> #include<iostream> #inclu ...

  2. Childlife旗下三驾马车

    Childlife旗下,尤其以 “提高免疫力”为口号的“三驾马车”:第一防御液.VC.紫雏菊,是相当热门的海淘产品.据说这是一系列“成分天然.有效治愈感冒提升免疫力.由美国著名儿科医生研发”的药物.

  3. tomcat在linux中的启动和查看相关信息

      打开终端cd /java/tomcat#执行bin/startup.sh #启动tomcatbin/shutdown.sh #停止tomcattail -f logs/catalina.out # ...

  4. php优化技巧

    PHP优化的目的是花最少的代价换来最快的运行速度与最容易维护的代码.本文给大家提供全面的优化技巧. 1.echo比print快. 2.使用echo的多重参数代替字符串连接. 3.在执行for循环之前确 ...

  5. UVa12171 hdu2771 UVaLive4291 Sculpture

    填坑系列(p.171) orz rjl 代码基本和rjl的一样 #include<cstdio> #include<cstring> #include<cstdlib&g ...

  6. 数学之路-分布式计算-disco(4)

    第一个參数iter是一个迭代器,涉及被map函数产生的键和值.它们是reduce实例. 在本例中.单词随机被托付给不同的reduce实例.然后,要单词同样,处理它的reduce也同样.可确保终于合计是 ...

  7. linux诡异的半连接(SYN_RECV)队列长度

    linux诡异的半连接(SYN_RECV)队列长度(一) >>转载请注明来源:飘零的代码 piao2010 ’s blog,谢谢!^_^>>本文链接地址:linux诡异的半连接 ...

  8. MyEclipse_6.0.1GA_E3.3.1集成版下载地址

    因在开发中经常使用到myeclipse 对比相关版本,还是觉得6.0 –6.5 比较适合开发,其他的开发起来比较卡,下面是下载地址 MyEclipse_6.0.1GA_E3.3.1集成版下载地址:   ...

  9. java获取计算机硬件参数

    public class HardWareUtils { /**   *   * 获取主板序列号   *   *   *   * @return   */ public static String g ...

  10. iOS UIKit:viewController之Segues (4)

    @import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/c ...