博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【MongoDB学习笔记32】MongoDB修改副本集配置
阅读量:7077 次
发布时间:2019-06-28

本文共 2893 字,大约阅读时间需要 9 分钟。

一、删除副本集成员

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,如需转载请自行联系原作者

你可能感兴趣的文章
《程序员的修炼——从优秀到卓越》
查看>>
使用.net开发手机管理软件 (十) 短信部分——VB.NET解码PDU
查看>>
sql2005 COM+ 目录要求 (警告)
查看>>
D3D绘图一点总结
查看>>
一起谈.NET技术,SharePoint 2010 BI(2):使用Visio Service
查看>>
报告称Windows7不安全 管理员权限是罪魁祸首
查看>>
Basic INFO - SUPPORTDIR变量的读取
查看>>
恋恋风尘
查看>>
mongodb - collMod
查看>>
学生如何提高专业英文阅读能力--施一公教授
查看>>
回顾2011,展望2012
查看>>
Android实例RSS客户端开发(3)--rss列表并显示在ui上
查看>>
PCI总线原理(四)
查看>>
unity, 设置帧率上限
查看>>
linux watchdog demo hacking
查看>>
两个函数连续性的讨论
查看>>
从头開始写项目Makefile(五):嵌套运行
查看>>
3种Nginx防盗链的方法
查看>>
UVA 10057 A mid-summer night's dream.
查看>>
JavaScript中的this
查看>>