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. [JIT_APP]Java基础知识总结

    一.Java语言的基础知识 1. 开发Java语言的公司 美国Sun(Sum Microsystems)公司开发.   2.Java的3个版本 J2SE(Java2 Standard Edition) ...

  2. Ubuntu14.04 安装配置Hadoop2.6.0

    目前关于Hadoop的安装配置教程书上.官方教程.博客都有很多,但由于对Linux环境的不熟悉以及各种教程或多或少有这样那样的坑,很容易导致折腾许久都安装不成功(本人就是受害人之一).经过几天不断尝试 ...

  3. hdu 4284 状态压缩

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4284 #include<cstdio> #include<cstring> # ...

  4. 正则表达式start(),end(),group()方法

    一.捕获组的概念 捕获组可以通过从左到右计算其开括号来编号,编号是从1 开始的.例如,在表达式 ((A)(B(C)))中,存在四个这样的组: 1     ((A)(B(C))) 2     (A) 3 ...

  5. 各种Markdown处理器的列表

    从MarkdownImplementations - Markdown Community Group可以找到一个实现markdown处理器的列表,如下: Name Language Type Des ...

  6. 亲测安装php

    亲测安装php1.tar zvxf php-5.3.8.tar.gz 2.cd php-5.3.83../configure \ --prefix=/usr/local/php \--with-mys ...

  7. mac下的secureCRT破解方案

    Mac下面的SecureCRT(附破解方案) 更新到最新的7.3.2 转自 http://bbs.weiphone.com/read-htm-tid-6939481.html 继续更新到7.3.2的破 ...

  8. js request

    比如你要获取aaa.aspx?id=2 使用方法为:var id= request('id'); 

  9. Android常用组件【转】

    UI相关 图片 Android-Universal-Image-Loader:com.nostra13.universalimageloader:异步加载.缓存.显示图片 ImageLoader:co ...

  10. 【SSMS增强工具】SQL Sharper 2014介绍

    产品介绍 SQL Sharper是一款SQL Server Management Studio插件,用于数据库对象快速查询.表结构查询.优化查询结果导出.代码生成等方面. 适用人群:T-SQL开发者. ...