MongoDB副本集配置系列五:副本集的在线迁移
MongoDB副本集的在线迁移
查看当前集群的状态:
{
"setName" : "gechongrepl",
"setVersion" : 11,
"ismaster" : true,
"secondary" : false,
"hosts" : [
"192.168.91.135:27017",
"192.168.91.133:27017"
],
"arbiters" : [
"192.168.91.144:27017"
],
"primary" : "192.168.91.135:27017",
"me" : "192.168.91.135:27017",
"maxBsonObjectSize" : 16777216,
"maxMessageSizeBytes" : 48000000,
"maxWriteBatchSize" : 1000,
"localTime" : ISODate("2015-06-17T02:29:52.582Z"),
"maxWireVersion" : 2,
"minWireVersion" : 0,
"ok" : 1
}
当前的副本集的状态为:
Primary:192.168.91.135:27017
Arbiters:192.168.91.144:27017
Secondary:192.168.91.133:27017
需求1:在副本集正常工作的情况下再添加一个节点。
1:模拟业务数据
gechongrepl:PRIMARY> db.test.count()
109000
gechongrepl:PRIMARY> for (i=0;i<10000;i++) db.test.insert({uid:i,uname:'testmoveonline'+i});
WriteResult({ "nInserted" : 1 })
gechongrepl:PRIMARY> db.test.count()
119000
gechongrepl:PRIMARY>
查看从节点的状态:
gechongrepl:SECONDARY> rs.slaveOk()
gechongrepl:SECONDARY> db.test.count()
119000
2:把从节点关掉
gechongrepl:SECONDARY> use admin
switched to db admin
gechongrepl:SECONDARY> db.shutdownServer() #查看当前的副本集的状态 gechongrepl:PRIMARY> rs.status() #再次插入数据 gechongrepl:PRIMARY> for (i=0;i<10000;i++) db.test.insert({uid:i,uname:'testmoveonline12345'+i});
WriteResult({ "nInserted" : 1 })
gechongrepl:PRIMARY> db.test.count()
129000
3:根据配置文件的配置,scpdata目录到新节点上。新节点IP为:192.168.91.132
[root@localhost mongodb]# scp -r ./data/ root@192.168.91.132:/root/software/mongodb/
root@192.168.91.132's password:
local.0 100% 64MB 21.3MB/s 00:03
local.1 100% 2047MB 21.8MB/s 01:34
test.0 100% 64MB 21.3MB/s 00:03
test.ns 100% 16MB 16.0MB/s 00:00
mongod.lock 100% 0 0.0KB/s 00:00
local.ns 100% 16MB 16.0MB/s 00:00
[root@localhost mongodb]# ls
bin data GNU-AGPL-3.0 log mongod.conf README THIRD-PARTY-NOTICES
[root@localhost mongodb]# scp -r ./log/ root@192.168.91.132:/root/software/mongodb/
root@192.168.91.132's password:
mongod 100% 1101KB 1.1MB/s 00:00
[root@localhost mongodb]#
查看192.168.91.132主机上的MongoDB目录已经存在scp过来的文件
[root@localhost mongodb]# ls
bin data GNU-AGPL-3.0 log mongod.conf README THIRD-PARTY-NOTICES
4:用scp过来的物理文件启动新节点
[root@localhost mongodb]# cd bin/
[root@localhost bin]# ./mongod --config /root/software/mongodb/mongod.conf
about to fork child process, waiting until server is ready for connections.
forked process: 30944
child process started successfully, parent exiting
5:在集群几点中加入新节点即可
gechongrepl:PRIMARY> rs.add("192.168.91.132:27017")
{
"_id" : 6,
"name" : "192.168.91.132:27017",
"health" : 1,
"state" : 6,
"stateStr" : "UNKNOWN",
"uptime" : 9,
"optime" : Timestamp(0, 0),
"optimeDate" : ISODate("1970-01-01T00:00:00Z"),
"lastHeartbeat" : ISODate("2015-06-17T02:49:43Z"),
"lastHeartbeatRecv" : ISODate("1970-01-01T00:00:00Z"),
"pingMs" : 0,
"lastHeartbeatMessage" : "still initializing"
}
6:remove刚才关掉的节点即可
gechongrepl:PRIMARY> rs.remove("192.168.91.133:27017")
如此再次重复这样的步骤即可把集群慢慢的转移到其他服务器上。
MongoDB副本集配置系列五:副本集的在线迁移的更多相关文章
- MongoDB副本集配置系列三:副本集的认证方式
1:副本集配置参考这篇博客: http://www.cnblogs.com/xiaoit/p/4478951.html 2:副本集的认证 假设有两台机器已经配置好了副本集(副本集罪一般最少3台机器,这 ...
- MongoDB副本集配置系列二:配置MongoDB副本集
接上一篇博客: http://www.cnblogs.com/xiaoit/p/4479066.html 1:首先创建3台虚拟机作为配置环境 IP1:192.168.91.128 IP2:192.16 ...
- MongoDB副本集配置系列十一:MongoDB 数据同步原理和自动故障转移的原理
1:数据同步的原理: 当Primary节点完成数据操作后,Secondary会做出一系列的动作保证数据的同步: 1:检查自己local库的oplog.rs集合找出最近的时间戳. 2:检查Primary ...
- MongoDB副本集配置系列十:MongoDB local库详解和数据同步原理
1:local库是MongoDB的系统库,记录着时间戳和索引和复制集等信息 gechongrepl:PRIMARY> use local switched to db local gechong ...
- MongoDB副本集配置系列七:MongoDB oplog详解
1:oplog简介 oplog是local库下的一个固定集合,Secondary就是通过查看Primary 的oplog这个集合来进行复制的.每个节点都有oplog,记录这从主节点复制过来的信息,这样 ...
- MongoDB副本集配置系列九:MongoDB 常见问题
What is a namespace in MongoDB? If you remove a document, does MongoDB remove it from disk? When doe ...
- MongoDB副本集配置系列八:MongoDB监控
1:Mongostat MongoDB2.6版本 MongoDB3.0版本 2:db.setProfilingLevel(2):打开profiler 类似于MySQL的slow log Profile ...
- MongoDB副本集配置系列六:定位MongoDB慢的原因
1:想知道哪些操作拖慢了MongoDB的速度,首先需要检查当前正在执行哪些操作. gechongrepl:PRIMARY> db.currentOp() "opid" : 7 ...
- MongoDB副本集配置系列一:安装MongoDB
1:下载MongoDB 2.6版本 https://fastdl.mongodb.org/win32/mongodb-win32-x86_64-2008plus-2.6.9.zip 2:解压 tar ...
随机推荐
- (转载):ASCII,Unicode和UTF-8 编码
UTF-8是Unicode的一种实现方式,也就是它的字节结构有特殊要求,所以我们说一个汉字的范围是0X4E00到0x9FA5,是指unicode值,至于放在utf-8的编码里去就是由三个字节来组织,所 ...
- Android Lint简介
Android Lint是SDK Tools 16 (ADT 16)之后才引入的工具,通过它对Android工程源代码进行扫描和检查,可发现潜在的问题,以便程序员及早修正这个问题.Android Li ...
- request.getParameter();的意思
对于httprequrest的request.getParameter()的作用,之前我只是在用它而不知道它到底有什么作用,今天看了一遍文章突然明白了其中的意思. 大致的内容如下: <form ...
- jQuery中attr()和prop()的区别,修改checked属性 jquery attr('checked' 不起作用 attr('checked' 不对
在做复选框全选按钮的时候,出现了一个问题,使用语句$.attr('checked',true),将复选框的属性改为被选中,在chrome浏览器中第一次点击有效后面就不行了,IE8倒是没有问题. 百度了 ...
- 我的Visual Studio 2013常用快捷键
声明及广告 所有功能针对C#开发配置而写,部分功能可能由插件提供,我会尽可能标注出相应的插件名称.为行文方便,所有快捷键以大写形式表示.太常用的快捷键,如Ctrl + C, Ctrl + Z, Ctr ...
- 初学 Delphi 嵌入汇编[1] - 汇编语言与机器语言
非科班出身, 现在才接触汇编, 惭愧呀, 好好学! 主选课本是清华大学王爽老师的<汇编语言>. 推荐 王爽老师的汇编网 汇编语言之前是机器语言. 机器语言是机器指令的集合, 机器指令是一系 ...
- 转:Logistic regression (逻辑回归) 概述
Logistic regression (逻辑回归)是当前业界比较常用的机器学习方法,用于估计某种事物的可能性.比如某用户购买某商品的可能性,某病人患有某种疾病的可能性,以及某广告被用户点击的可能性等 ...
- Kafka:ZK+Kafka+Spark Streaming集群环境搭建(三)安装spark2.2.1
如何搭建配置centos虚拟机请参考<Kafka:ZK+Kafka+Spark Streaming集群环境搭建(一)VMW安装四台CentOS,并实现本机与它们能交互,虚拟机内部实现可以上网.& ...
- ueditor插入自定义内容和样式
UEditor是由百度web前端研发部开发所见即所得富文本web编辑器,具有轻量,可定制,注重用户体验等特点 通过UEditor提供的API接口可以很方便的读写操作内容并设置编辑器里的样式 页 ...
- 转:android root tcpdump抓包强烈推荐
转:http://www.cnblogs.com/findyou/p/3491035.html 写的相当详细且完整,业界良心. adb push d:\tcpdump /data/local/ adb ...