MongoDB基础之九 replication复制集
准备工作:创建目录
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复制集的更多相关文章
- MongoDB for OPS 02:复制集 RS 配置
写在前面的话 对于生产环境而言,除非是非常不重要的业务,且该业务允许我们出现一定时间的停机,我们一般才会使用单节点,且该单节点必须要有完善的备份手段. RS 复制集 我们这里采取一主两从的方式搭建复制 ...
- MongoDB DBA 实践4-----创建复制集
一.复制 复制允许多个数据库服务器共享相同数据的功能,从而确保冗余并促进负载平衡 1.数据冗余及可用性 复制技术提供数据冗余及可用性,在不同的数据库服务器上使用多个数据副本,复制技术防止单个数据库服务 ...
- 02 . MongoDB复制集,分片集,备份与恢复
复制集 MongoDB复制集RS(ReplicationSet): 基本构成是1主2从的结构,自带互相监控投票机制(Raft(MongoDB)Paxos(mysql MGR 用的是变种)) 如果发生主 ...
- MongoDB复制集
1.1 MongoDB复制集简介 一组Mongodb复制集,就是一组mongod进程,这些进程维护同一个数据集合.复制集提供了数据冗余和高等级的可靠性,这是生产部署的基础. 1.1.1 复制集的目的 ...
- Windows 下MongoDB复制集配置
1.下载服务.https://www.mongodb.com/ 点击products 下拉第二列MongoDB server 选择 4.0.6 2.下载下来后 有限管理员运行 一路安装,可以不用 ...
- MongoDB学习4:MongoDB复制集机制和原理,搭建复制集
1.复制集的作用 1.1 MongoDB复制集的主要意义在于实现服务高可用 1.2 它的实现依赖于两个方面的功能: · 数据写入时将数据迅速复制到另一个独立节点上 · 在接收写入的 ...
- mongodb 复制集
mongodb 复制集 复制集简介 Mongodb复制集由一组Mongod实例(进程)组成,包含一个Primary节点和多个Secondary节点,Mongodb Driver(客户端)的所有数据都写 ...
- 关于 MongoDB 复制集
为什么要使用复制集 1.备份数据通过自带的 mongo_dump/mongo_restore 工具也可以实现备份,但是毕竟没有复制集的自动同步备份方便. 2.故障自动转移部署了复制集,当主节点挂了后, ...
- MongoDB 复制集节点增加移除及节点属性配置
复制集(replica Set)或者副本集是MongoDB的核心高可用特性之一,它基于主节点的oplog日志持续传送到辅助节点,并重放得以实现主从节点一致.再结合心跳机制,当感知到主节点不可访问或宕机 ...
随机推荐
- 根据XPATH去查看修改xml文件节点的内容
首先给出xml文件解析的路径,然后去读取节点的内容. package com.inetpsa.eqc.threads; import java.util.List; import java.io.Fi ...
- hadoop hdfs uri详解
body{ font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI& ...
- jemalloc Mongodb Nginx 优化
下载 http://www.canonware.com/jemalloc/download.html 下载 wget http://www.canonware.com/download/jemallo ...
- ID3决策树预测的java实现
刚才写了ID3决策树的建立,这个是通过决策树来进行预测.这里主要用到的就是XML的遍历解析,比较简单. 关于xml的解析,参考了: http://blog.csdn.net/soszou/articl ...
- 批量删除ASP.NET中的缓存(cache)
IDictionaryEnumerator em = HttpContext.Current.Cache.GetEnumerator(); while (em.MoveNext()) { ...
- nginx的一些配置
map $http_user_agent $***_build_version { default "***.exe"; "~Windows NT 10.0" ...
- MVC笔记3:JQuery AutoComplete组件
1.引入以下js和css <link href="@Url.Content("~/Content/Site.css")" rel="styles ...
- C#中的协变OUT和逆变
泛型接口和泛型委托中经常使用可变性 in 逆变,out 协变 从 list<string>转到list<object> 称为协变 (string 从object 派生,那么 ...
- 把div 当文字来进行布局控制
两边对齐 text-align: justify; text-justify: distribute-all-lines;/*ie6-8*/ text-align-last: justify;/* i ...
- css--position和float
1.元素设置position:relative或者position:absolute后,才能激活left,top,right,bottom和z-index属性,默认情况下这些属性并未激活,设置了也会无 ...