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日志持续传送到辅助节点,并重放得以实现主从节点一致.再结合心跳机制,当感知到主节点不可访问或宕机 ...
随机推荐
- 在IOS应用中从竖屏模式强制转换为横屏模式
http://www.cnblogs.com/mrhgw/archive/2012/07/18/2597218.html 在 iPhone 应用里,有时我们想强行把显示模式从纵屏改为横屏(反之亦然), ...
- ubuntu16安装KVM
apt install qemu-kvm libvirt-bin apt install openvswitch-switch
- tp框架链接数据库的基本操作
<?php namespace Admin\Controller; use Think\Controller; class MainController extends Controller { ...
- 在spring 3.0中的@value
在spring 3.0中,可以通过使用@value,对一些如xxx.properties文件 中的文件,进行键值对的注入,例子如下: 1 首先在applicationContext.xml中加入: ...
- 【转】23种设计模式UML图
原文:http://blog.csdn.net/bwwlpnn/article/details/7421628
- svn 几个好用的命令
Mac下操作的命令 1. 删除目录及子目录下,未添加的文件 svn status . | grep '^?' | awk '{print $2}' | xargs rm -rf 2.恢复根目录及子目录 ...
- DrawerLayout学习笔记
基本步骤: 1>在XML中将DrawerLayout作为根视图 2>根视图中放两个View,第一个是主视图,即DrawerLayout隐藏的时候的视图,第二是就DrawerLayout的视 ...
- 详解Grunt插件之LiveReload实现页面自动刷新(两种方案)
http://www.jb51.net/article/70415.htm 含Grunt系列教程 这篇文章主要通过两种方案详解Grunt插件之LiveReload实现页面自动刷新,需要的朋友可以 ...
- 1.1.2.托管对象模型(Core Data 应用程序实践指南)
托管对象模型即对象图,可以看成实体类的描述,规定了数据字段. 要想创建托管对象模型,需生成NSManagedObjectModel类的实例.
- bzoj 3611[Heoi2014]大工程 虚树+dp
题意: 给一棵树 每次选 k 个关键点,然后在它们两两之间 新建 C(k,2)条 新通道. 求: 1.这些新通道的代价和 2.这些新通道中代价最小的是多少 3.这些新通道中代价最大的是多少 分析:较常 ...