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之间的数据全然一致,大大减少了单点故障的风险. ...
随机推荐
- 用 webpack 构建 node 后端代码,使其支持 js 新特性并实现热重载
https://zhuanlan.zhihu.com/p/20782320?utm_source=tuicool&utm_medium=referral
- [extjs] ExtJs4.2 Form 表单提交
基本代码: <script> Ext.onReady(function(){ Ext.create('Ext.form.Panel', { title: '登录', bodyPadding ...
- Mongodb 与sql 语句对照
此处用mysql中的sql语句做例子,C# 驱动用的是samus,也就是上文中介绍的第一种. 引入项目MongoDB.dll //创建Mongo连接 var mongo = new Mongo(&qu ...
- POJ 3211 Washing Cloths(01背包变形)
Q: 01背包最后返回什么 dp[v], v 是多少? A: 普通01背包需要遍历, 从大到小. 但此题因为物品的总重量必定大于背包容量, 所以直接返回 dp[V] 即可 update 2014年3月 ...
- POJ 1337 A Lazy Worker(区间DP, 背包变形)
Description There is a worker who may lack the motivation to perform at his peak level of efficiency ...
- ping命令和telnet命令
1.检查能不能连接上远程主机 ping 主机ip 2.检查远程主机端口是不是开放 telnet 198.10.10.69 1521 Trying 198.10.10.69...Connected t ...
- 动易CMS漏洞收集
动易SiteWeaver6.8短消息0day跨站漏洞 user用户登陆,默认账号密码 admin/admin888 短消息代码模式下编辑,预览 <img src="../Skin/bl ...
- Unity中Oculus分屏相机和普通相机一键切换
Unity中Oculus分屏相机和普通相机一键切换 一.OCulus 分屏相机介绍 在VR开发工程中,总会觉得OC分屏的处理太慢,严重浪费时间啊! 但是不使用有不好调试,来回切换相机就成为了一个必须. ...
- flash 逐字,逐行歌词实现,添加伪3D效果
项目结构: 效果如图: 项目为公司项目,下载人员禁止用于商业项目中. 项目开发工具:FlashDevelop 点击下载
- 【BZOJ3387】[Usaco2004 Dec]Fence Obstacle Course栅栏行动 线段树
[BZOJ3387][Usaco2004 Dec]Fence Obstacle Course栅栏行动 Description 约翰建造了N(1≤N≤50000)个栅栏来与牛同乐.第i个栅栏的z坐标为[ ...