准备工作:创建目录

 mkdir -p /home/m17 //home/m18 /home/m19 /home/mlog

1:启动3个实例,且声明实例属于某复制集

 # ./bin/mongod --dbpath /home/m17 --logpath /home/mlog/m17.log --fork --port  --replSet rs2 --smallfiles
# ./bin/mongod --dbpath /home/m18 --logpath /home/mlog/m18.log --fork --port --replSet rs2 --smallfiles
# ./bin/mongod --dbpath /home/m19 --logpath /home/mlog/m19.log --fork --port --replSet rs2 --smallfiles

注:--smallfiles 最小文件创建实例

2:配置复制级

 var rsconf = {
_id:'rs2',
members:
[
{_id:,
host:'127.0.0.1:27017'
},
{_id:,
host:'127.0.0.1:27018'
},
{_id:,
host:'127.0.0.1:27019'
} ]
}
 > printjson(rsconf)
{
"_id" : "rs2",
"members" : [
{
"_id" : ,
"host" : "127.0.0.1:27017"
},
{
"_id" : ,
"host" : "127.0.0.1:27018"
},
{
"_id" : ,
"host" : "127.0.0.1:27019"
}
]
}

3: 根据配置做初始化

 > rs.initiate(rsconf)
;
{
"info" : "Config now saved locally. Should come online in about a minute.",
"ok" :
}
rs2:SECONDARY> rs.status();
{
"set" : "rs2",
"date" : ISODate("2016-05-26T00:43:57Z"),
"myState" : ,
"members" : [
{
"_id" : ,
"name" : "127.0.0.1:27017",
"health" : ,
"state" : ,
"stateStr" : "SECONDARY",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("2016-05-26T00:43:11Z"),
"self" : true
},
{
"_id" : ,
"name" : "127.0.0.1:27018",
"health" : ,
"state" : ,
"stateStr" : "STARTUP2",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("1970-01-01T00:00:00Z"),
"lastHeartbeat" : ISODate("2016-05-26T00:43:54Z"),
"lastHeartbeatRecv" : ISODate("2016-05-26T00:43:52Z"),
"pingMs" :
},
{
"_id" : ,
"name" : "127.0.0.1:27019",
"health" : ,
"state" : ,
"stateStr" : "STARTUP2",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("1970-01-01T00:00:00Z"),
"lastHeartbeat" : ISODate("2016-05-26T00:43:44Z"),
"lastHeartbeatRecv" : ISODate("2016-05-26T00:43:53Z"),
"pingMs" :
}
],
"ok" :
}

4: 添加节点

 rs2:PRIMARY> rs.add('127.0.0.1:27018')
{ "down" : [ "127.0.0.1:27018" ], "ok" : }
rs2:PRIMARY> rs.status
function () { return db._adminCommand("replSetGetStatus"); }
rs2:PRIMARY> rs.status()
{
"set" : "rs2",
"date" : ISODate("2016-05-26T00:51:01Z"),
"myState" : ,
"members" : [
{
"_id" : ,
"name" : "127.0.0.1:27017",
"health" : ,
"state" : ,
"stateStr" : "PRIMARY",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("2016-05-26T00:50:53Z"),
"self" : true
},
{
"_id" : ,
"name" : "127.0.0.1:27019",
"health" : ,
"state" : ,
"stateStr" : "SECONDARY",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("2016-05-26T00:50:53Z"),
"lastHeartbeat" : ISODate("2016-05-26T00:51:00Z"),
"lastHeartbeatRecv" : ISODate("2016-05-26T00:50:59Z"),
"pingMs" : ,
"lastHeartbeatMessage" : "syncing to: 127.0.0.1:27017",
"syncingTo" : "127.0.0.1:27017"
},
{
"_id" : ,
"name" : "127.0.0.1:27018",
"health" : ,
"state" : ,
"stateStr" : "SECONDARY",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("2016-05-26T00:50:53Z"),
"lastHeartbeat" : ISODate("2016-05-26T00:50:59Z"),
"lastHeartbeatRecv" : ISODate("2016-05-26T00:51:00Z"),
"pingMs" : ,
"lastHeartbeatMessage" : "syncing to: 127.0.0.1:27017",
"syncingTo" : "127.0.0.1:27017"
}
],
"ok" :
}

5:查看状态

 rs.status();

6:删除节点

 rs2:PRIMARY> rs.remove('127.0.0.1:27018');
Thu May ::36.621 DBClientCursor::init call() failed
Thu May ::36.621 Error: error doing query: failed at src/mongo/shell/query.js:
Thu May ::36.622 trying reconnect to 127.0.0.1:
Thu May ::36.622 reconnect 127.0.0.1: ok
rs2:PRIMARY> rs.status();
{
"set" : "rs2",
"date" : ISODate("2016-05-26T00:49:38Z"),
"myState" : ,
"members" : [
{
"_id" : ,
"name" : "127.0.0.1:27017",
"health" : ,
"state" : ,
"stateStr" : "PRIMARY",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("2016-05-26T00:49:36Z"),
"self" : true
},
{
"_id" : ,
"name" : "127.0.0.1:27019",
"health" : ,
"state" : ,
"stateStr" : "SECONDARY",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("2016-05-26T00:49:36Z"),
"lastHeartbeat" : ISODate("2016-05-26T00:49:38Z"),
"lastHeartbeatRecv" : ISODate("2016-05-26T00:49:37Z"),
"pingMs" : ,
"lastHeartbeatMessage" : "syncing to: 127.0.0.1:27017",
"syncingTo" : "127.0.0.1:27017"
}
],
"ok" :
}

7:主节点插入数据

 rs2:PRIMARY> show dbs
local .029296875GB
rs2:PRIMARY>
rs2:PRIMARY>
rs2:PRIMARY> use test
switched to db test
rs2:PRIMARY>
rs2:PRIMARY> db.stu.insert({title:'hello'});
rs2:PRIMARY>
rs2:PRIMARY>
rs2:PRIMARY> show tables;
stu
system.indexes

8:连接secondary查询同步情况

 # ./bin/mongo -port
MongoDB shell version: 2.4.
connecting to: 127.0.0.1:/test
rs2:SECONDARY> use test
switched to db test
rs2:SECONDARY> show tables
Thu May ::57.272 error: { "$err" : "not master and slaveOk=false", "code" : } at src/mongo/shell/query.js:

8.1 出现上述错误,是因为slave默认不许读写

 rs2:SECONDARY> rs.slaveOk();
rs2:SECONDARY> show tables
stu
system.indexes
rs2:SECONDARY> db.stu.find();
{ "_id" : ObjectId("57464a73c79dad862e06cd3b"), "title" : "hello" }

#看到与primary 一致的数据

 9 主节点down机器 ,primary节点自动漂移

 rs2:PRIMARY> use admin
switched to db admin
rs2:PRIMARY> db.shutdownServer();
Thu May ::33.316 DBClientCursor::init call() failed rs2:SECONDARY> rs.status()
{
"set" : "rs2",
"date" : ISODate("2016-05-26T01:19:38Z"),
"myState" : ,
"syncingTo" : "127.0.0.1:27018",
"members" : [
{
"_id" : ,
"name" : "127.0.0.1:27017",
"health" : ,
"state" : ,
"stateStr" : "(not reachable/healthy)",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("2016-05-26T00:59:32Z"),
"lastHeartbeat" : ISODate("2016-05-26T01:19:38Z"),
"lastHeartbeatRecv" : ISODate("2016-05-26T01:19:33Z"),
"pingMs" :
},
{
"_id" : ,
"name" : "127.0.0.1:27019",
"health" : ,
"state" : ,
"stateStr" : "SECONDARY",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("2016-05-26T00:59:32Z"),
"errmsg" : "syncing to: 127.0.0.1:27018",
"self" : true
},
{
"_id" : ,
"name" : "127.0.0.1:27018",
"health" : ,
"state" : ,
"stateStr" : "PRIMARY",
"uptime" : ,
"optime" : Timestamp(, ),
"optimeDate" : ISODate("2016-05-26T00:59:32Z"),
"lastHeartbeat" : ISODate("2016-05-26T01:19:38Z"),
"lastHeartbeatRecv" : ISODate("2016-05-26T01:19:36Z"),
"pingMs" : ,
"syncingTo" : "127.0.0.1:27017"
}
],
"ok" :
}

MongoDB基础之九 replication复制集的更多相关文章

  1. MongoDB for OPS 02:复制集 RS 配置

    写在前面的话 对于生产环境而言,除非是非常不重要的业务,且该业务允许我们出现一定时间的停机,我们一般才会使用单节点,且该单节点必须要有完善的备份手段. RS 复制集 我们这里采取一主两从的方式搭建复制 ...

  2. MongoDB DBA 实践4-----创建复制集

    一.复制 复制允许多个数据库服务器共享相同数据的功能,从而确保冗余并促进负载平衡 1.数据冗余及可用性 复制技术提供数据冗余及可用性,在不同的数据库服务器上使用多个数据副本,复制技术防止单个数据库服务 ...

  3. 02 . MongoDB复制集,分片集,备份与恢复

    复制集 MongoDB复制集RS(ReplicationSet): 基本构成是1主2从的结构,自带互相监控投票机制(Raft(MongoDB)Paxos(mysql MGR 用的是变种)) 如果发生主 ...

  4. MongoDB复制集

    1.1 MongoDB复制集简介 一组Mongodb复制集,就是一组mongod进程,这些进程维护同一个数据集合.复制集提供了数据冗余和高等级的可靠性,这是生产部署的基础. 1.1.1 复制集的目的 ...

  5. Windows 下MongoDB复制集配置

    1.下载服务.https://www.mongodb.com/   点击products 下拉第二列MongoDB server  选择 4.0.6 2.下载下来后 有限管理员运行 一路安装,可以不用 ...

  6. MongoDB学习4:MongoDB复制集机制和原理,搭建复制集

    1.复制集的作用   1.1 MongoDB复制集的主要意义在于实现服务高可用   1.2 它的实现依赖于两个方面的功能:    · 数据写入时将数据迅速复制到另一个独立节点上    · 在接收写入的 ...

  7. mongodb 复制集

    mongodb 复制集 复制集简介 Mongodb复制集由一组Mongod实例(进程)组成,包含一个Primary节点和多个Secondary节点,Mongodb Driver(客户端)的所有数据都写 ...

  8. 关于 MongoDB 复制集

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

  9. MongoDB 复制集节点增加移除及节点属性配置

    复制集(replica Set)或者副本集是MongoDB的核心高可用特性之一,它基于主节点的oplog日志持续传送到辅助节点,并重放得以实现主从节点一致.再结合心跳机制,当感知到主节点不可访问或宕机 ...

随机推荐

  1. extJS4.2.0 环境搭建教程(一)

    一.环境搭建

  2. 滚动时div的背景图片随之滚动

    在浏览一些网站时发现有一种效果是当滚动时看到某一DIV的背景也会随之滚动,如下: 当滚动时内容位置保持不变,但是内容后面的背景却在随着滚动.随之我通过审查元素看到了其是通过background-pos ...

  3. MYSQL管理----数据库删除恢复

    (1) 如果备份了,就好解决了.略. (2)如果日志打开,使用mysqlbinlog来恢复. mysqlbinlog工具的使用,大家可以看MySQL的帮助手册.里面有详细的用, 在这个例子中,重点是- ...

  4. 获取手机wifi下的网络地址

    #import "getIPhoneIP.h" #import <ifaddrs.h> #import <arpa/inet.h> @implementat ...

  5. Eclipse 打开js文件时出现 Could not open the editor...

    选择 window-->General-->Editors-->File Associations -->(在右边上面的框中选择jsp或者你打开的文件类型)-->(然后在 ...

  6. VS2010下创建的VB.NET项目打包发布安装包的流程

    VS2010下创建的VB.NET项目打包发布安装包的流程 参考:http://blog.csdn.net/liuyanlinglanq/article/details/8609675  关于relea ...

  7. 长平狐 Cocos2d-x 的“HelloWorld” 深入分析

                              Cocos2d-x 的“HelloWorld” 深入分析 本节所用Cocos2d-x版本:cocos2d-1.0.1-x-0.12.0 不能免俗,一 ...

  8. poj2886线段树(单点修改,区间查询)

    Who Gets the Most Candies? Time Limit: 5000MS   Memory Limit: 131072K Total Submissions: 11955   Acc ...

  9. iOS开发笔记 - 界面调试神器Reveal

    http://blog.csdn.net/jackfrued/article/details/50934092     Reveal是iOS开发工具中的神器之一,它能够在应用程序运行过程中调试应用程序 ...

  10. sql语句的截取字符串下标是从1开始

    这里的指的sqliter数据库 substr函数 substr(date,1,10)