当前位置: 首页 > news >正文

【MongoDB学习笔记32】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
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,如需转载请自行联系原作者

相关文章:

  • iptables防火墙 --Linux详解
  • CentOS 7.2 安装图解教程
  • MongoDB主从
  • Linux系统使用lvm扩展根分区
  • 【人工智能】 火爆的机器学习和人工智能,为何在金融业四处碰壁?
  • 定制你的敏捷方法:以结果为导向
  • Java并发编程(六)发布与逸出
  • linux 查看网卡流量的方法
  • 自己制作 XP With SP3 系统光盘 包括驱动SATA集成AHCI驱动
  • 使用Maven运行单元测试
  • 创建服务
  • python01 用户交互程序
  • Mongodb 3.2 Manual阅读笔记:CH9 存储
  • 第101天:CSS3中transform-style和perspective
  • 不用申请服务号就可以开发微信支付/支付宝/QQ钱包支付!附:直接可用的代码+demo...
  • [iOS]Core Data浅析一 -- 启用Core Data
  • [译]前端离线指南(上)
  • 4月23日世界读书日 网络营销论坛推荐《正在爆发的营销革命》
  • Codepen 每日精选(2018-3-25)
  • CSS居中完全指南——构建CSS居中决策树
  • golang 发送GET和POST示例
  • IOS评论框不贴底(ios12新bug)
  • JavaScript异步流程控制的前世今生
  • JAVA并发编程--1.基础概念
  • Laravel Telescope:优雅的应用调试工具
  • session共享问题解决方案
  • ViewService——一种保证客户端与服务端同步的方法
  • Windows Containers 大冒险: 容器网络
  • 从重复到重用
  • 基于阿里云移动推送的移动应用推送模式最佳实践
  • 那些年我们用过的显示性能指标
  • 入口文件开始,分析Vue源码实现
  • 协程
  • 自定义函数
  • 【运维趟坑回忆录 开篇】初入初创, 一脸懵
  • ​油烟净化器电源安全,保障健康餐饮生活
  • ### Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLTr
  • #微信小程序:微信小程序常见的配置传值
  • #我与Java虚拟机的故事#连载04:一本让自己没面子的书
  • #我与Java虚拟机的故事#连载08:书读百遍其义自见
  • (3)选择元素——(17)练习(Exercises)
  • (aiohttp-asyncio-FFmpeg-Docker-SRS)实现异步摄像头转码服务器
  • (delphi11最新学习资料) Object Pascal 学习笔记---第8章第5节(封闭类和Final方法)
  • (js)循环条件满足时终止循环
  • (动手学习深度学习)第13章 计算机视觉---图像增广与微调
  • (三)mysql_MYSQL(三)
  • (十)DDRC架构组成、效率Efficiency及功能实现
  • (一) springboot详细介绍
  • (轉)JSON.stringify 语法实例讲解
  • ./include/caffe/util/cudnn.hpp: In function ‘const char* cudnnGetErrorString(cudnnStatus_t)’: ./incl
  • .bat批处理(六):替换字符串中匹配的子串
  • .NET CORE 第一节 创建基本的 asp.net core
  • .net core 客户端缓存、服务器端响应缓存、服务器内存缓存
  • .NET Core、DNX、DNU、DNVM、MVC6学习资料
  • .Net(C#)常用转换byte转uint32、byte转float等