【MongoDB学习笔记32】MongoDB修改副本集配置

本文涉及的产品
云数据库 MongoDB,通用型 2核4GB
简介:

一、删除副本集成员

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
spock:PRIMARY> rs.config()   
{    
         "_id"  "spock" ,    
         "version"  : 1,    
         "members"  : [    
                 {    
                         "_id"  : 0,    
                         "host"  "192.168.1.112:27017"    
                 },    
                 {    
                         "_id"  : 1,    
                         "host"  "192.168.1.113:27017"    
                 }    
         ]    
}    
spock:PRIMARY> rs.remove( "192.168.1.113:27017" )    
{    
         "errmsg"  "exception: can't find self in new replset config" ,    
         "code"  : 13433,    
         "ok"  : 0    
}    
spock:PRIMARY> rs.remove( "192.168.1.112:27017" )    
2015-02-02T21:59:13.303+0800 DBClientCursor::init call() failed    
2015-02-02T21:59:13.304+0800 Error: error doing query: failed at src /mongo/shell/query .js:81    
2015-02-02T21:59:13.305+0800 trying reconnect to 127.0.0.1:27017 (127.0.0.1) failed    
2015-02-02T21:59:13.308+0800 reconnect 127.0.0.1:27017 (127.0.0.1) ok    
spock:PRIMARY> rs.config()    
{    
         "_id"  "spock" ,    
         "version"  : 2,    
         "members"  : [    
                 {    
                         "_id"  : 1,    
                         "host"  "192.168.1.113:27017"    
                 }    
         ]    
}

   

二、添加副本集成员   

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
spock:PRIMARY> rs.add( "192.168.1.112:27017" )    
"ok"  : 1 }    
spock:PRIMARY> rs.config()    
{    
         "_id"  "spock" ,    
         "version"  : 3,    
         "members"  : [    
                 {    
                         "_id"  : 1,    
                         "host"  "192.168.1.113:27017"    
                 },    
                 {    
                         "_id"  : 2,    
                         "host"  "192.168.1.112:27017"    
                 }    
         ]    
}

   
   
从上述过程来看,配置文档中version字段都会自增,它的初始值为1;

 

三、或者通过rs.reconfig()函数修改副本集

例如,将host用主机名来替代ip地址

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
[root@localhost ~] # ping host113   
PING host113 (192.168.1.113) 56(84) bytes of data.    
64 bytes from host113 (192.168.1.113): icmp_seq=1 ttl=64  time =0.060 ms    
64 bytes from host113 (192.168.1.113): icmp_seq=2 ttl=64  time =0.030 ms    
64 bytes from host113 (192.168.1.113): icmp_seq=3 ttl=64  time =0.026 ms    
64 bytes from host113 (192.168.1.113): icmp_seq=4 ttl=64  time =1.04 ms    
--- host113  ping  statistics ---    
4 packets transmitted, 4 received, 0% packet loss,  time  3001ms    
rtt min /avg/max/mdev  = 0.026 /0 .289 /1 .041 /0 .434 ms    
[root@localhost ~] # mongo    
MongoDB shell version: 2.6.7    
connecting to:  test    
spock:PRIMARY> rs.config()    
{            
     "_id"  "spock" ,            
     "version"  : 3,            
     "members"  : [                    
                     "_id"  : 1,  "host"  "192.168.1.113:27017" },
                     "_id"  : 2,  "host"  "192.168.1.112:27017" }            
                 ]    
  }    
spock:PRIMARY> var config=rs.config()   
spock:PRIMARY> config.members[0].host= "host113:27017"    
host113:27017    
spock:PRIMARY> rs.reconfig(config)    
2015-02-02T22:21:22.793+0800 DBClientCursor::init call() failed    
2015-02-02T22:21:22.795+0800 trying reconnect to 127.0.0.1:27017 (127.0.0.1) faile
2015-02-02T22:21:22.797+0800 reconnect 127.0.0.1:27017 (127.0.0.1) ok    
reconnected to server after rs  command  ( which  is normal)
spock:PRIMARY> rs.config()   
{            
     "_id"  "spock" ,            
     "version"  : 4,            
     "members"  : [                    
             "_id"  : 1, "host"  "host113:27017" },
             "_id"  : 2,  "host"  "192.168.1.112:27017" }            
                 ]    
}    
spock:PRIMARY>

 

对于复杂的副本集配置,rs.reconfig函数修改比rs.add和rs.remove更有用;




本文转自 bannerpei 51CTO博客,原文链接:http://blog.51cto.com/281816327/1610912,如需转载请自行联系原作者

相关实践学习
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
相关文章
|
3月前
|
NoSQL 网络协议 Unix
第6期 MongoDB配置启动方式
第6期 MongoDB配置启动方式
288 0
|
5月前
|
存储 NoSQL MongoDB
mongodb 存引擎及配置
mongodb 存引擎及配置
|
5月前
|
NoSQL 数据可视化 MongoDB
Windows MongoDB的安装及配置图文说明(非常详细)
Windows MongoDB的安装及配置图文说明(非常详细)
318 0
|
5月前
|
NoSQL Linux MongoDB
MongoDB配置用户名和密码
MongoDB配置用户名和密码
471 0
|
24天前
|
监控 NoSQL 算法
【MongoDB】 MongoDB的副本集是什么?
【4月更文挑战第1天】【MongoDB】 MongoDB的副本集是什么?
|
1月前
|
存储 缓存 NoSQL
|
2月前
|
运维 NoSQL Linux
MongoDB详解(六)——MongoDB主从同步配置
MongoDB详解(六)——MongoDB主从同步配置
53 5
|
6月前
|
NoSQL MongoDB
MongoDB分片+副本集高可用集群的启停步骤
MongoDB分片+副本集高可用集群的启停步骤
140 0
|
3月前
|
监控 NoSQL MongoDB
第5期 MongoDB配置用户名密码认证登录
第5期 MongoDB配置用户名密码认证登录
548 0
|
5月前
|
DataWorks NoSQL 网络安全
MongoDB的配置问题
MongoDB的配置问题
19 1