MongoDB之Replica Set(复制集复制)
MongoDB支持两种复制模式:
- 主从复制(Master/Slave)
- 复制集复制(Replica Set)
下面主要记录我在centos虚拟机上安装replica set,主要参考:http://docs.mongodb.org/manual/tutorial/deploy-replica-set/
首先准备好3份配置文件:
port = 27017 dbpath = /home/bells/install/data1
logpath = /home/bells/install/log1/1.log fork = true
replSet = rs0
port = 27016 dbpath = /home/bells/install/data2
logpath = /home/bells/install/log2/2.log fork = true
replSet = rs0
port = 27015 dbpath = /home/bells/install/data3
logpath = /home/bells/install/log3/3.log fork = true
replSet = rs0
然后再启动这3个mongodb服务
sudo ./mongodb1/bin/mongod --smallfiles --config 1.conf
sudo ./mongodb2/bin/mongod --smallfiles --config 2.conf
sudo ./mongodb3/bin/mongod --smallfiles --config 3.conf
其实smallfiles也应该写进*.conf文件中的。
最后配置:
主要是通过下面的命令
rs.initiate() 使用默认的配置初始化replica set在当前的服务器
rs.status() 显示当前replica set的状态
rs.add(serverInfo) 增加新的成员到replica set 中
rs.addArb(serverInfo) 增加一个arbiter到replica set中
rs.initiate()
{
"info2" : "no configuration explicitly specified -- making one",
"me" : "localhost.localdomain:27017",
"info" : "Config now saved locally. Should come online in about a minute.",
"ok" : 1
}
> rs.conf()
{
"_id" : "rs0",
"version" : 1,
"members" : [
{
"_id" : 0,
"host" : "localhost.localdomain:27017"
}
]
}
rs0:PRIMARY> rs.add("localhost.localdomain:27016")
{ "ok" : 1 }
rs0:PRIMARY> rs.add("localhost.localdomain:27015")
{ "ok" : 1 }
rs0:PRIMARY> rs.status()
{
"set" : "rs0",
"date" : ISODate("2014-02-23T01:43:16Z"),
"myState" : 1,
"members" : [
{
"_id" : 0,
"name" : "localhost.localdomain:27017",
"health" : 1,
"state" : 1,
"stateStr" : "PRIMARY",
"uptime" : 602,
"optime" : Timestamp(1393119782, 1),
"optimeDate" : ISODate("2014-02-23T01:43:02Z"),
"self" : true
},
{
"_id" : 1,
"name" : "localhost.localdomain:27016",
"health" : 1,
"state" : 5,
"stateStr" : "STARTUP2",
"uptime" : 17,
"optime" : Timestamp(0, 0),
"optimeDate" : ISODate("1970-01-01T00:00:00Z"),
"lastHeartbeat" : ISODate("2014-02-23T01:43:15Z"),
"lastHeartbeatRecv" : ISODate("2014-02-23T01:43:15Z"),
"pingMs" : 0,
"lastHeartbeatMessage" : "initial sync need a member to be primary or secondary to do our initial sync"
},
{
"_id" : 2,
"name" : "localhost.localdomain:27015",
"health" : 1,
"state" : 5,
"stateStr" : "STARTUP2",
"uptime" : 14,
"optime" : Timestamp(0, 0),
"optimeDate" : ISODate("1970-01-01T00:00:00Z"),
"lastHeartbeat" : ISODate("2014-02-23T01:43:16Z"),
"lastHeartbeatRecv" : ISODate("2014-02-23T01:43:16Z"),
"pingMs" : 1,
"lastHeartbeatMessage" : "syncThread: 12520 new file allocation failure"
}
],
"ok" : 1
}
rs0:PRIMARY> db.person.insert({"name":"jack", "age":20})
rs0:PRIMARY> db.person.find()
{ "_id" : ObjectId("5309529869d3a7216c59ef2a"), "name" : "jack", "age" : 20 }
[bells@localhost install]$ ./mongodb2/bin/mongo --port 27016
MongoDB shell version: 2.4.5
connecting to: 127.0.0.1:27016/test
rs0:SECONDARY> db.person.find()
error: { "$err" : "not master and slaveOk=false", "code" : 13435 }
rs0:SECONDARY> rs.slaveOk();
rs0:SECONDARY> db.person.find()
{ "_id" : ObjectId("5309529869d3a7216c59ef2a"), "name" : "jack", "age" : 20 }
安装部署过程中,遇到两个问题:
1. 启动mongodb时,错误日志:
Sun Feb 23 09:47:57.930 [initandlisten] ERROR: Insufficient free space for journal files
Sun Feb 23 09:47:57.930 [initandlisten] Please make at least 3379MB available in /home/bells/install/data1/journal or use --smallfiles
Sun Feb 23 09:47:57.930 [initandlisten]
Sun Feb 23 09:47:57.953 [initandlisten] exception in initAndListen: 15926 Insufficient free space for journals, terminating
解决办法就是,启动的时候,加个 --smallfiles : 这个参数默认值是false,如果设为true,则会是每个文件最大的大小限定为512M而不是默认的2G
2. 在secondary中,查询时:
rs0:SECONDARY> db.person.find()
error: { "$err" : "not master and slaveOk=false", "code" : 13435 }
这个是正常的,因为SECONDARY默认是不允许读写操作的,可以:
rs0:SECONDARY> db.slaveOk();
来解决!
MongoDB之Replica Set(复制集复制)的更多相关文章
- mongodb 复制集
mongodb 复制集 复制集简介 Mongodb复制集由一组Mongod实例(进程)组成,包含一个Primary节点和多个Secondary节点,Mongodb Driver(客户端)的所有数据都写 ...
- 认识MongoDB复制集
从这一篇开始,我们要踏上MongoDB进阶之路啦,想想还有点小开心呢.一筐猪镇楼. 引入复制集 我们先来想一个场景,如果本地项目使用MongoDB,都是下载,安装,连接一条龙服务.这实际也就是 ...
- mongodb复制集Replica Set使用简介
MongoDB高可用 对于MongoDB,可以支持使用单机模式提供服务,但是在实际的生产环境中,单机模式将面临很大的风险,一旦这个数据库服务出现问题,就会导致线上的服务出现错误甚至崩溃.因此,在实际生 ...
- MongoDB 复制集模式Replica Sets
1.概述 复制集是一个带有故障转移的主从集群.是从现有的主从模式演变而来,增加了自动故障转移和节点成员自动恢复. 复制集模式中没有固定的主结点,在启动后,多个服务节点间将自动选举 产生一个主结点.该主 ...
- 【MongoDB】windows平台搭建Mongo数据库复制集(类似集群)(转)
原文链接:[MongoDB]windows平台搭建Mongo数据库复制集(类似集群)(一) Replica Sets(复制集)是在mongodDB1.6版本开始新增的功能,它可以实现故障自动切换和自 ...
- MongoDB 复制集 (三) 内部数据同步
一 数据同步 一个健康的secondary在运行时,会选择一个离自己最近的,数据比自己新的节点进行数据同步.选定节点后,它会从这个节点拉取oplog同步日志,具体流程是这样的: ...
- MongoDB 复制集(二) 选举 自动故障切换
一 复制集的高可用性简介 复制集通过故障自动切换来实现高可用性,当主节点出现故障的时候,从节点可以通过选举成为主节点,而这个过程在大多数当情况下是自动进行的,不需要手动干预.在某些情况 ...
- MongoDB 复制集 (一) 成员介绍
一 MongoDB 复制集简介 MongoDB的复制机制主要分为两种: Master-Slave (主从复制) 这个已经不建议使用 ...
- 【MongoDB】windows平台搭建Mongo数据库复制集(相似集群)(一)
Replica Sets(复制集)是在mongodDB1.6版本号開始新增的功能.它能够实现故障自己主动切换和自己主动修复功能成员节点的功能,各个DB之间的数据全然一致,大大减少了单点故障的风险. ...
随机推荐
- Android弹出Dialog使用举例
Android详细的对话框AlertDialog.Builder使用方法 7种形式的Android Dialog使用举例 第30章.常见对话框之一AlertDialog(从零开始学Android)
- shell基础篇(五)条件判断
写脚本时:有时要判断字符串是否相等,数字测试.这对后面学习的shell语句,循环,条件语句做好基础. 条件判断格式 1. test condition : test命令 2. [ conditio ...
- conn.setAutoCommit(false)数据回滚设置
前言:介绍一点爱混淆的概念. 1.mysql中默认 autocommit=1:事物自动提交. 可通过 select @@autocommit;查看 但是是设置事务自动提交模式为set autocomm ...
- 基于Cocos2d-x学习OpenGL ES 2.0系列——初识MVP(3)
在上一篇文章中,我在介绍vertex shader的时候挖了一个坑:CC_MVPMatrix.它其实是一个uniform,每一个Cocos2d-x预定义的shader都包含有这个uniform,但是如 ...
- C++中的枚举变量
至从C语言开始enum类型就被作为用户自定义分类有限集合常量的方法被引入到了语言当中,而且一度成为C++中定义编译期常量的唯一方法(后来在类中引入了静态整型常量).根据上面对enum类型的描述,有以下 ...
- cocos2d-x游戏引擎核心之三——主循环和定时器
一.游戏主循环 在介绍游戏基本概念的时候,我们曾介绍了场景.层.精灵等游戏元素,但我们却故意避开了另一个同样重要的概念,那就是游戏主循环,这是因为 Cocos2d 已经为我们隐藏了游戏主循环的实现.读 ...
- MVC Route路由
由于某些原因,需要默认区域,所以需要对路由进行设置 具体实现如下: using System.Web; using System.Web.Mvc; using System.Web.Routing; ...
- Computer Science Theory for the Information Age-5: 学习理论——VC维的定义以及一些例子
学习理论——VC维的定义以及一些例子 本文主要介绍一些学习理论上的东西.首先,我们得明确,从训练集上学习出来的分类器的最终目标是用于预测未知的样本,那么我们在训练的时候该用多少的样本才能使产生的分类器 ...
- 通过身份证分析出生年月日、性别、年龄的SQL语句
),) ) ),)<>'X' ) ) )<>'X' ),)),)),)) ),)),)),)) ) as int)) where [出生日期]<>'' #字符串格式 ...
- MQTT的学习研究(十五) MQTT 和android整合文章
详细参考: How to Implement Push Notifications for Android http://tokudu.com/2010/how-to-implement-push- ...