mongodb replica set 添加/删除节点方法--http://www.ii123.com/jc/bc/bczh/258948.html

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 配置

[[email protected] 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 节点服务

[[email protected] 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
[[email protected] 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 删除旧结点数据目录

 代码如下  

[[email protected] mongodb]$ rm -rf  /mongodb/data04

mongodb replica set 添加/删除节点方法--http://www.ii123.com/jc/bc/bczh/258948.html,布布扣,bubuko.com

时间: 2024-08-08 01:05:00

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

Hadoop动态添加/删除节点(datanode和tacktracker)

总的来说,正确的做法是优先通过配置文件,再在具体机器上进行相应进程的启动/停止操作. 网上一些资料说在调整配置文件的时候,优先使用主机名而不是IP进行配置. 总的来说添加/删除DataNode和TaskTracker的方法非常相似,只是操作的配置项和使用的命令有微小差异. 1. DataNode 1.0 配置文件 在master/namenode下修改配置文件conf/mapred-site.xml. 关键参数dfs.hosts和dfs.hosts.exclude. 注意:不同hadoop版本的

redis cluster 添加/删除节点操作

RedisCluster 添加/删除节点 添加节点新配置两个测试节点8008和9009 [[email protected]192-13-10-77 ~]# /usr/local/redis-4.0.9/bin/redis-server /u02/redis/8008/conf/redis_8008.conf [[email protected]192-13-10-77 ~]# /usr/local/redis-4.0.9/bin/redis-server /u02/redis/9009/con

添加删除节点

<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>jQuery插入,复制.替换和删除节点</title> <script type="text/javascript" src="jquery-1.3.2.js"></scri

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

<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>DOM增删改查</title> <style type="text/css"> div{ border:#306 1px solid; width:200px; height:30px; margin:10px; } #div

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

jQuery中提供了三种删除节点的方法:remove().detach().empty(),本文详细分析这三种方法. 最容易区分的是empty(),该方法严格上属于“清空节点”,即删除其子节点,自身并不会删除.举个栗子: 1 <!doctype html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>remove和detach对

RedisCluster 添加/删除节点

一,redis cluster命令行 查看复制打印? //集群(cluster) CLUSTER INFO 打印集群的信息 CLUSTER NODES 列出集群当前已知的所有节点(node),以及这些节点的相关信息. //节点(node) CLUSTER MEET <ip> <port> 将 ip 和 port 所指定的节点添加到集群当中,让它成为集群的一份子. CLUSTER FORGET <node_id> 从集群中移除 node_id 指定的节点. CLUSTER

pdf如何添加水印以及删除水印方法介绍

相信大家对于水印都不陌生,在纸张上,它具有防伪的作用.而在信息时代的今天,电子水印可以维护我们的版权,防止他人抄袭我们的智慧成果.我们如何才能给pdf添加水印和删除水印,今天小编就给大家介绍方法供大家使用.操作软件:迅捷PDF编辑器软件地址:https://www.xunjiepdf.com/editor1.在给pdf文件添加水印以及删除水印之前,我们需要准备一款软件使用,这里小编使用的是迅捷pdf编辑器.2.当我们打开pdf文件后,我们需要找到水印工具,我们点击界面上方的文档按钮后弹出了许多工

第五部分 架构篇 第十五章 MongoDB Replica Sets 架构(动态增加删除结点)

1.Replica Set增加结点 MongoDB Replica Set不仅提供高可用性的解决方案,它也同时提供负载均衡的解决方案,增减Replica Sets结点在实际应用中非常普遍,比如当应用的读压力暴增时,3台结点的环境已经不能满足需求,那么就需要增加一些结点将压力平均分配一下,当应用的压力小时,可以减少一些结点来减少硬件资源的成本,总是是一个长期且持续的工作. 官方给我们提供了2个方案用于增加结点,一种是通过oplog来增加结点,一种是通过数据库快照(--fastsync)和oplog

redis cluster 添加 删除 重分配 节点

redis cluster配置好,并运行一段时间后,我们想添加节点,或者删除节点,该怎么办呢.  一,redis cluster命令 //集群(cluster) CLUSTER INFO 打印集群的信息 CLUSTER NODES 列出集群当前已知的所有节点(node),以及这些节点的相关信息. //节点(node) CLUSTER MEET <ip> <port> 将 ip 和 port 所指定的节点添加到集群当中,让它成为集群的一份子. CLUSTER FORGET <n