replica set多服务器主从,添加,删除节点,肯定会经常遇到的。下面详细说明一下,添加,删除节点的2种方法。

  一,利用rs.reconfig,来添加,删除节点

  1,添加节点

 代码如下  

repmore:PRIMARY> config = {_id:"repmore",members:[{_id:0,host:'127.0.0.1:27017',priority :2},{_id:1,host:'127.0.0.1:27018',priority:1}]};   //添加节点

repmore:PRIMARY> rs.reconfig(config);   //使配置生效

repmore:PRIMARY> rs.status();     //查看节点状态

  节点添加成功。

  注意:新增节点的replSet要和其他节点要一样

  2,删除节点(删除节点前最好是先关闭需要删除的节点,之后通过命令 rs.remove 来删除)

 代码如下  

repmore:PRIMARY> config = {_id:"repmore",members:[{_id:0,host:'127.0.0.1:27017',priority :2}]};     //删除节点

repmore:PRIMARY> rs.reconfig(config);   //使配置生效

repmore:PRIMARY> rs.status();   //查看节点状态

  二,利用rs.add和rs.remove来添加删除节点

 代码如下  

repmore:PRIMARY> rs.add("127.0.0.1:27018");     //添加节点

repmore:PRIMARY> rs.remove("127.0.0.1:27018");  //删除节

  注意:利用rs.add和rs.remove是不用rs.reconfig来使用配置生效的。

  最后对于删除节点我这里再附一个标准流程给各位

  相应的节点,操作如下:

 代码如下  

--1 查看当前 Replica Set 配置

[mongo@redhatB mongodb]$ mongo 127.0.0.1:27018
MongoDB shell version: 2.2.1
connecting to: 127.0.0.1:27018/test
rs0:PRIMARY> rs.conf();
{
        "_id" : "rs0",
        "version" : 4,
        "members" : [
                {
                        "_id" : 0,
                        "host" : "redhatB.example.com:27018"
                },
                {
                        "_id" : 1,
                        "host" : "redhatB.example.com:27019"
                },
                {
                        "_id" : 2,
                        "host" : "redhatB.example.com:27020"
                },
                {
                        "_id" : 3,
                        "host" : "redhatB.example.com:27021"
                }
        ]
}

备注:计划删除节点 "_id" : 3。

--2 关闭 27021 节点服务

[mongo@redhatB data04]$ ps -ef | grep 27021
mongo    11733     1  0 21:03 ?        00:00:15 mongod -f /pgdata_xc/mongodb/data04/mongodb_27021.conf
mongo    14422  2953  0 21:53 pts/0    00:00:00 mongo 127.0.0.1:27021
mongo    14490  4027  0 21:54 pts/1    00:00:00 grep 27021
[mongo@redhatB data04]$ kill 11733

--3 查看 replica set 状态

rs0:PRIMARY> rs.status();
{
        "set" : "rs0",
        "date" : ISODate("2012-11-22T13:57:15Z"),
        "myState" : 1,
        "members" : [
                {
                        "_id" : 0,
                        "name" : "redhatB.example.com:27018",
                        "health" : 1,
                        "state" : 1,
                        "stateStr" : "PRIMARY",
                        "uptime" : 21279,
                        "optime" : Timestamp(1353589624000, 1),
                        "optimeDate" : ISODate("2012-11-22T13:07:04Z"),
                        "self" : true
                },
                {
                        "_id" : 1,
                        "name" : "redhatB.example.com:27019",
                        "health" : 1,
                        "state" : 2,
                        "stateStr" : "SECONDARY",
                        "uptime" : 18908,
                        "optime" : Timestamp(1353589624000, 1),
                        "optimeDate" : ISODate("2012-11-22T13:07:04Z"),
                        "lastHeartbeat" : ISODate("2012-11-22T13:57:13Z"),
                        "pingMs" : 0
                },
                {
                        "_id" : 2,
                        "name" : "redhatB.example.com:27020",
                        "health" : 1,
                        "state" : 2,
                        "stateStr" : "SECONDARY",
                        "uptime" : 18900,
                        "optime" : Timestamp(1353589624000, 1),
                        "optimeDate" : ISODate("2012-11-22T13:07:04Z"),
                        "lastHeartbeat" : ISODate("2012-11-22T13:57:14Z"),
                        "pingMs" : 0
                },
                {
                        "_id" : 3,
                        "name" : "redhatB.example.com:27021",
                        "health" : 0,
                        "state" : 8,
                        "stateStr" : "(not reachable/healthy)",
                        "uptime" : 0,
                        "optime" : Timestamp(1353589624000, 1),
                        "optimeDate" : ISODate("2012-11-22T13:07:04Z"),
                        "lastHeartbeat" : ISODate("2012-11-22T13:55:20Z"),
                        "pingMs" : 0,
                        "errmsg" : "socket exception [CONNECT_ERROR] for redhatB.example.com:27021"
                }
        ],
        "ok" : 1
}

备注:最后一个节点 stateStr 状态为 “not reachable/healthy”。
 
--4 删除节点

rs0:PRIMARY> rs.remove("redhatB.example.com:27021");
Thu Nov 22 21:58:45 DBClientCursor::init call() failed
Thu Nov 22 21:58:45 query failed : admin.$cmd {
replSetReconfig: { _id: "rs0", version: 5, members: [ { _id: 0, host:
"redhatB.example.com:27018" }, { _id: 1, host:
"redhatB.example.com:27019" }, { _id: 2, host:
"redhatB.example.com:27020" } ] } } to: 127.0.0.1:27018
Thu Nov 22 21:58:45 Error: error doing query: failed src/mongo/shell/collection.js:155
Thu Nov 22 21:58:45 trying reconnect to 127.0.0.1:27018
Thu Nov 22 21:58:45 reconnect 127.0.0.1:27018 ok
rs0:SECONDARY>
rs0:PRIMARY>

--5 再次查看 replica set 配置

rs0:PRIMARY> rs.conf();
{
        "_id" : "rs0",
        "version" : 5,
        "members" : [
                {
                        "_id" : 0,
                        "host" : "redhatB.example.com:27018"
                },
                {
                        "_id" : 1,
                        "host" : "redhatB.example.com:27019"
                },
                {
                        "_id" : 2,
                        "host" : "redhatB.example.com:27020"
                }
        ]
}

  备注:节点 "redhatB.example.com:27021" 已删除。

  --6 删除旧结点数据目录

 代码如下  

[mongo@redhatB mongodb]$ rm -rf  /mongodb/data04

mongodb replica set 添加/删除节点方法--http://www.ii123.com/jc/bc/bczh/258948.html的更多相关文章

  1. MongoDB添加删除节点

    副本集添加删除节点 sharding添加删除节点 先将节点设置为hidden,再remove

  2. redis cluster 添加/删除节点操作

    RedisCluster 添加/删除节点 添加节点新配置两个测试节点8008和9009 [root@--- ~]# /usr/local/redis-/bin/redis-server /u02/re ...

  3. Mongodb 3.6 副本集测试及添加删除节点等操作

    下载tar包并安装curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.6.8.tgz [root@mysqlt ...

  4. 节点操作-创建并添加&删除节点&替换&克隆节点

    <head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" ...

  5. jQuery中删除节点方法remove()、detach()、empty()分析

    jQuery中提供了三种删除节点的方法:remove().detach().empty(),本文详细分析这三种方法. 最容易区分的是empty(),该方法严格上属于“清空节点”,即删除其子节点,自身并 ...

  6. RedisCluster 添加/删除节点

    一,redis cluster命令行 //集群(cluster) CLUSTER INFO 打印集群的信息 CLUSTER NODES 列出集群当前已知的所有节点(node),以及这些节点的相关信息. ...

  7. Hadoop日常维护系列——Hadoop添加删除节点

    添加节点 1.修改host    和普通的datanode一样.添加namenode的ip 2.修改namenode的配置文件conf/slaves    添加新增节点的ip或host 3.在新节点的 ...

  8. redis集群添加删除节点

    Redis3.0集群添加节点 1:首先把需要添加的节点启动 cd /usr/local/cluster/ mkdir 7006 cp /usr/local/cluster/redis.conf  /u ...

  9. Java ArrayList正确循环添加删除元素方法及分析

    在阿里巴巴Java开发手册中,有这样一条规定: 但是手册中并没有给出具体原因,本文就来深入分析一下该规定背后的思考. 一.foreach循环 foreach循环(Foreach loop)是计算机编程 ...

随机推荐

  1. 【WIP】数据结构与算法入门

    创建: 2017/12/25    

  2. Rails 插入代码与注释

    醉了醉了,在原来那个表格最后加了然后更新博客,然后最后写的内容就没了.来来回回试了n次都一样.不得已新开一个    插入代码  <% ... %>  打印值  <%= ... %&g ...

  3. React实战之60s倒计时按钮(发送短信验证按钮)

    React实战之60s倒计时按钮——短信验证按钮 导入:(antd组件——Form表单) import { Button, Form, Input } from 'antd'; const FormI ...

  4. 04-Vue中的动画

    Vue中的动画 为什么要有动画:动画能够提高用户的体验,帮助用户更好的理解页面中的功能: -使用过渡类名 1.html <div id="app"> <input ...

  5. hdu2031

    http://acm.hdu.edu.cn/showproblem.php?pid=2031 #include<stdio.h> #include<math.h> #inclu ...

  6. 理解 Java 构造函数不可以继承

    参考来源:http://www.52bowen.com/a/2604620.html

  7. 268 Missing Number 缺失的数字

    给出一个包含 0, 1, 2, ..., n 中 n 个数的序列,找出 0 .. n 中没有出现在序列中的那个数.案例 1输入: [3,0,1]输出: 2案例 2输入: [9,6,4,2,3,5,7, ...

  8. Firebug

    Firebug是网页浏览器火狐下的一款开发类插件,它集HTML查看和编辑.JavaScript控制台.网络状态监视器于一体,是开发JavaScript.CSS.HTML和Ajax的得力助手.F12打开 ...

  9. 理解 CSS 布局和块级格式上下文

    前言 BFC 的概念始于 CSS2,是个蛮古老的 CSS 话题了,网上也到处能搜到 BFC 的介绍,但是都不够简洁.本文系翻译自 Rachel Andrew 女士的博文 Understanding C ...

  10. 一个完整的网站记录(springmvc hibernate juery bootstrap)

    总述 该网站为了满足测试人员自主添加测试条目,编辑更新信息和删除信息,同时同步到后台数据库的基本功能. 关键技术:oracle数据库.tomcat8.5.springMVC.Hibernate.aja ...