Mongodb延迟复制节点配置

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介:

背景:

  我们一般配置的Mongodb主从,或者Mongodb复制集,数据同步都是实时的。但如果在主节点上进行了错误的数据操作,这时候就会导致整个集群的数据都出错。因此,我们可以在一个集群中,挑选一个mongodb实例,用作复制延迟。当在主节点上误操作的时候,集群中有一个实例是不受影响的。这时候就可以利用这台不受影响的实例进行数据恢复。

  以上就是mongodb的延迟复制节点的功能,当主节点进行一次数据操作后,延迟复制节不立马进行数据同步操作,而是在一段时间后,才同步数据。


配置:

  以我的实验环境为例,以下为我的mongodb复制集:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
cmh0:PRIMARY> rs.status()
{
         "set"  "cmh0" ,
         "date"  : ISODate( "2016-08-22T02:43:16.240Z" ),
         "myState"  : 1,
         "members"  : [
                 {
                         "_id"  : 1,
                         "name"  "192.168.52.128:27017" ,
                         "health"  : 1,
                         "state"  : 1,
                         "stateStr"  "PRIMARY" ,
                         "uptime"  : 82,
                         "optime"  : Timestamp(1470581983, 1),
                         "optimeDate"  : ISODate( "2016-08-07T14:59:43Z" ),
                         "electionTime"  : Timestamp(1471833721, 1),
                         "electionDate"  : ISODate( "2016-08-22T02:42:01Z" ),
                         "configVersion"  : 1,
                         "self"  true
                 },
                 {
                         "_id"  : 2,
                         "name"  "192.168.52.135:27017" ,
                         "health"  : 1,
                         "state"  : 2,
                         "stateStr"  "SECONDARY" ,
                         "uptime"  : 71,
                         "optime"  : Timestamp(1470581983, 1),
                         "optimeDate"  : ISODate( "2016-08-07T14:59:43Z" ),
                         "lastHeartbeat"  : ISODate( "2016-08-22T02:43:15.138Z" ),
                         "lastHeartbeatRecv"  : ISODate( "2016-08-22T02:43:14.978Z" ),
                         "pingMs"  : 0,
                         "lastHeartbeatMessage"  "could not find member to sync from" ,
                         "configVersion"  : 1
                 },
                 {
                         "_id"  : 3,
                         "name"  "192.168.52.135:27019" ,
                         "health"  : 1,
                         "state"  : 2,
                         "stateStr"  "SECONDARY" ,
                         "uptime"  : 75,
                         "optime"  : Timestamp(1470581983, 1),
                         "optimeDate"  : ISODate( "2016-08-07T14:59:43Z" ),
                         "lastHeartbeat"  : ISODate( "2016-08-22T02:43:15.138Z" ),
                         "lastHeartbeatRecv"  : ISODate( "2016-08-22T02:43:15.138Z" ),
                         "pingMs"  : 0,
                         "configVersion"  : 1
                 }
         ],
         "ok"  : 1
}

  这时还未配置延迟复制节点,所以数据是实时同步的:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
cmh0:PRIMARY> use cmhtest
switched to db cmhtest
cmh0:PRIMARY> db.cmh.insert({ "name" : "ChenMinghui" })
WriteResult({  "nInserted"  : 1 })
cmh0:PRIMARY> rs.printReplicationInfo()
configured oplog size:   990MB
log length start to end: 195secs (0.05hrs)
oplog first event  time :  Mon Aug 22 2016 10:51:22 GMT+0800 (CST)
oplog last event  time :   Mon Aug 22 2016 10:54:37 GMT+0800 (CST)
now:                     Mon Aug 22 2016 10:55:00 GMT+0800 (CST)
cmh0:PRIMARY> rs.printSlaveReplicationInfo()
source : 192.168.52.135:27017
         syncedTo: Mon Aug 22 2016 10:54:37 GMT+0800 (CST)
         0 secs (0 hrs) behind the primary 
source : 192.168.52.135:27019
         syncedTo: Mon Aug 22 2016 10:54:37 GMT+0800 (CST)
         0 secs (0 hrs) behind the primary

  可以看到两个Secondary节点都在同一时间实时同步了数据。


  配置192.168.52.135:27017为延迟复制节点:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
cmh0:PRIMARY> cfg=rs.conf();
{
         "_id"  "cmh0" ,
         "version"  : 1,
         "members"  : [
                 {
                         "_id"  : 1,
                         "host"  "192.168.52.128:27017" ,
                         "arbiterOnly"  false ,
                         "buildIndexes"  true ,
                         "hidden"  false ,
                         "priority"  : 1,
                         "tags"  : {
                         },
                         "slaveDelay"  : 0,
                         "votes"  : 1
                 },
                 {
                         "_id"  : 2,
                         "host"  "192.168.52.135:27017" ,
                         "arbiterOnly"  false ,
                         "buildIndexes"  true ,
                         "hidden"  false ,
                         "priority"  : 1,
                         "tags"  : {
                         },
                         "slaveDelay"  : 0,
                         "votes"  : 1
                 },
                 {
                         "_id"  : 3,
                         "host"  "192.168.52.135:27019" ,
                         "arbiterOnly"  false ,
                         "buildIndexes"  true ,
                         "hidden"  false ,
                         "priority"  : 1,
                         "tags"  : {
                         },
                         "slaveDelay"  : 0,
                         "votes"  : 1
                 }
         ],
         "settings"  : {
                 "chainingAllowed"  true ,
                 "heartbeatTimeoutSecs"  : 10,
                 "getLastErrorModes"  : {
                 },
                 "getLastErrorDefaults"  : {
                         "w"  : 1,
                         "wtimeout"  : 0
                 }
         }
}
cmh0:PRIMARY> cfg.members[1].priority=0
0
cmh0:PRIMARY> cfg.members[1].slaveDelay=30
30
cmh0:PRIMARY> rs.reconfig(cfg);
"ok"  : 1 }
cmh0:PRIMARY> rs.conf()
{
         "_id"  "cmh0" ,
         "version"  : 2,
         "members"  : [
                 {
                         "_id"  : 1,
                         "host"  "192.168.52.128:27017" ,
                         "arbiterOnly"  false ,
                         "buildIndexes"  true ,
                         "hidden"  false ,
                         "priority"  : 1,
                         "tags"  : {
                         },
                         "slaveDelay"  : 0,
                         "votes"  : 1
                 },
                 {
                         "_id"  : 2,
                         "host"  "192.168.52.135:27017" ,
                         "arbiterOnly"  false ,
                         "buildIndexes"  true ,
                         "hidden"  false ,
                         "priority"  : 0,
                         "tags"  : {
                         },
                         "slaveDelay"  : 30,
                         "votes"  : 1
                 },
                 {
                         "_id"  : 3,
                         "host"  "192.168.52.135:27019" ,
                         "arbiterOnly"  false ,
                         "buildIndexes"  true ,
                         "hidden"  false ,
                         "priority"  : 1,
                         "tags"  : {
                         },
                         "slaveDelay"  : 0,
                         "votes"  : 1
                 }
         ],
         "settings"  : {
                 "chainingAllowed"  true ,
                 "heartbeatTimeoutSecs"  : 10,
                 "getLastErrorModes"  : {
                 },
                 "getLastErrorDefaults"  : {
                         "w"  : 1,
                         "wtimeout"  : 0
                 }
         }
}

  可以看到192.168.52.135:27017节点出现了"slaveDelay":30的值,说明该节点的同步时间向后推迟了30秒。

  具体大家可以测试一下,延迟复制时间大概会在30秒左右。有一点要注意,mongodb的系统时间必须一致,否则会造成延迟复制异常,导致在规定同步时间到了之后不进行同步操作。










本文转自 icenycmh 51CTO博客,原文链接:http://blog.51cto.com/icenycmh/1841001,如需转载请自行联系原作者
相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
目录
相关文章
|
8月前
|
NoSQL 网络协议 Unix
第6期 MongoDB配置启动方式
第6期 MongoDB配置启动方式
412 0
|
5月前
|
NoSQL MongoDB Windows
MongoDB 读写分离——Windows MongoDB 副本集配置
MongoDB 读写分离——Windows MongoDB 副本集配置
111 0
|
6月前
|
消息中间件 NoSQL 中间件
MongoDB主从结构、仲裁节点
【7月更文挑战第2天】
96 0
|
6月前
|
存储 NoSQL 关系型数据库
MongoDB的配置服务器和复制机制
【7月更文挑战第2天】MongoDB配置服务器存储分片和权限元数据,支持在主节点故障时保持读服务。关键组件,性能影响显著。复制集包含Primary和Secondary,通过oplog实现数据同步,类似MySQL binlog。oplog的幂等性可能导致大量set操作,且大小受限,可能导致从节点需全量同步。读写分离提升效率,主从切换确保高可用。
72 0
|
7月前
|
安全 NoSQL 程序员
老程序员分享:mongodb4.xxx安装,和基本配置
老程序员分享:mongodb4.xxx安装,和基本配置
60 0
|
8月前
|
监控 NoSQL 安全
【MongoDB 专栏】MongoDB 的复制集:高可用性配置
【5月更文挑战第10天】MongoDB的复制集是实现数据高可用性的重要机制,由主节点和次节点构成,主节点处理写操作,次节点同步数据确保一致。在主节点故障时,次节点自动提升接替,保证服务不间断。通过复制集,可实现数据保护、持续服务,适用于关键业务系统和数据备份。配置时需关注网络稳定性、节点性能和数据一致性。案例显示,复制集能有效保障服务高可用,防止数据丢失和业务中断,是现代数据库管理的关键工具。在数据驱动的世界,复制集为高可用性提供了坚实保障。
150 0
【MongoDB 专栏】MongoDB 的复制集:高可用性配置
|
8月前
|
DataWorks NoSQL 关系型数据库
DataWorks操作报错合集之在使用 DataWorks 进行 MongoDB 同步时遇到了连通性测试失败,实例配置和 MongoDB 白名单配置均正确,且同 VPC 下 MySQL 可以成功连接并同步,但 MongoDB 却无法完成同样的操作如何解决
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
128 1
|
8月前
|
存储 缓存 NoSQL
|
8月前
|
运维 NoSQL Linux
MongoDB详解(六)——MongoDB主从同步配置
MongoDB详解(六)——MongoDB主从同步配置
361 5
|
8月前
|
NoSQL Java MongoDB
mongoDB动态配置文档名称
mongoDB动态配置文档名称
100 0