Redis搭建(七):Redis的Cluster集群动态增删节点

时间:2022-05-22 06:36:14

一、引言

  上一篇文章我们一步一步的教大家搭建了Redis的Cluster集群环境,形成了3个主节点和3个从节点的Cluster的环境。当然,大家可以使用 Cluster info 命令查看Cluster集群的状态,也可以使用Cluster Nodes 命令来详细了解Cluster集群每个节点的详细信息和关系。我们可以在主节点上增加数据、操作数据,也可以在从节点上读取数据,这些操作当然都没有问题。我们今天这篇文章主要是讲解一下如何在不停掉Cluster集群环境的情况下,动态的往集群环境中增加主、从节点和动态的从集群环境中删除节点。好了,废话不多说,开始我们今天的讲解。在开始之前,先要说明一下,因为redis的动态扩容操作都是通过redis-trib.rb脚本文件来完成的,所以我们先来看看对这个脚本文件的说明,效果如图:

[root@linux redis] # ruby redis-trib.rb

Redis搭建(七):Redis的Cluster集群动态增删节点

二、Cluster集群增加操作

  现在正好开始我们的操作,我把增加节点和删除节点分开来写,并且增加或者删除节点,我都分了两个方面来说,一个方面是主节点的操作,另一个方面是从节点的操作,因为主、从节点在操作上会有差异,所以分来来说。增加节点的顺序是先增加Master主节点,然后在增加Slave从节点。当然这篇文章是在上一篇文章所讲的Cluster集群模式的基础之上来讲的,那就让我们先来看看上一篇文章所建立的Cluster集群模式的详细信息。效果如图:

Redis搭建(七):Redis的Cluster集群动态增删节点

Redis搭建(七):Redis的Cluster集群动态增删节点

1、动态增加Master主服务器节点

       1.1、创建目录7006(Master主节点文件夹)和7007(Slave从节点文件夹),并从以前Cluster集群节点7000-7005任一节点中拷贝配置文件redis.conf到7006和7007目录下。

 [root@linux redis-cluster]# pwd

 [root@linux redis-cluster]# /root/application/program/redis-cluster/

 [root@linux redis-cluster]# mkdir 7006 7007

 [root@linux redis-cluster]# ls

    7000 7001 7002 7003 7004 7005 7006 7007

 [root@linux redis-cluster]# cp 7000/redis.conf 7006

 [root@linux redis-cluster]# cp 7000/redis.conf 7007

1.1.1、创建目录:

Redis搭建(七):Redis的Cluster集群动态增删节点         

   1.1.2、拷贝配置文件:

Redis搭建(七):Redis的Cluster集群动态增删节点

1.2、修改配置文件,将7006和7007目录下面的redis.conf配置文件的端口进行相应修改,与自己的目录名称保持一致,修改项目如下:(在linux环境下可以执行如下命令进行全局替换::%s/7000/7006/g,%s/7000/7007/g,保存并退出则可)

  1.2.1、7006节点的配置文件:redis.conf

bind 192.168.127.130

port 7006

daemonize yes

pidfile /var/run/redis-7006.pid

logfile /root/application/program/redis-cluster/7006/redis.log

dir /root/application/program/redis-cluster/7006/

cluster-enabled yes

cluster-config-file nodes-7006.conf

cluster-node-timeout 15000

appendonly yes

appendfsync always

  1.2.2、7007节点的配置文件:redis.conf    

bind 192.168.127.130

port 7007

daemonize yes

pidfile /var/run/redis-7007.pid

logfile /root/application/program/redis-cluster/7007/redis.log

dir /root/application/program/redis-cluster/7007/

cluster-enabled yes

cluster-config-file nodes-7007.conf

cluster-node-timeout 15000

appendonly yes

appendfsync always

1.3、启动7006和7007目录下Redis实例,并查看效果。

[root@linux redis]# pwd

[root@linux redis]# /root/application/program/redis/

[root@linux redis]# redis-server ../redis-cluster/7006/redis.conf

[root@linux redis]# redis-server ../redis-cluster/7007/redis.conf

效果如图:

Redis搭建(七):Redis的Cluster集群动态增删节点

Redis搭建(七):Redis的Cluster集群动态增删节点

1.4、将7006主节点加入到Cluster集群。

[root@linux redis]# pwd

[root@linux redis]# /root/application/program/redis/

 [root@linux redis]# ruby redis-trib.rb add-node 192.168.127.130:7006 192.168.127.130:7000

  注意:当添加新节点成功以后,新的节点不会有任何数据,因为他没有分配任何的数据Slot(哈希slots),这一步需要手动操作。

       1.4.1、增加7006:(192.168.127.130:7006,截图地址错误,端口号是7006,不是9006)

  Redis搭建(七):Redis的Cluster集群动态增删节点

   1.4.2、节点增加成功。

   Redis搭建(七):Redis的Cluster集群动态增删节点

    1.4.3、cluster info 验证:

  Redis搭建(七):Redis的Cluster集群动态增删节点

   1.4.4、cluster nodes验证:

  Redis搭建(七):Redis的Cluster集群动态增删节点

  1.5、为7006Master主节点分配数据Slots,分配方法是从集群中知道任何一个主节点(因为只有Master主节点才有数据slots),然后对其进行重新分片工作。               

[root@linux redis]# pwd

[root@linux redis]# /root/application/program/redis/

[root@linux redis]# ruby redis-trib.rb reshard 192.168.127.130:7000

  1.5.1、分配数据槽:

   Redis搭建(七):Redis的Cluster集群动态增删节点

   1.5.2、选择接收数据槽的节点和数据槽产生的方式:

  Redis搭建(七):Redis的Cluster集群动态增删节点

  1.5.3、执行分配计划:

  Redis搭建(七):Redis的Cluster集群动态增删节点

  1.5.4、数据槽分配成功:

  Redis搭建(七):Redis的Cluster集群动态增删节点

2、动态增加Slave从服务器节点

  在增加主节点7006的时候,前面的3步是共有的,也就是从1.1-1.3,之后才是建立主节点的内容,前面的3步骤针对从节点7007也是必须的,我只是把这些步骤写到了创建主节点7006的步骤里,大家请知晓。

   2.1、将7007节点增加到集群中

[root@linux redis]# pwd

[root@linux redis]# /root/application/program/redis/

[root@linux redis]# ruby redis-trib.rb add-node 192.168.127.130:7007 192.168.127.130:7000

效果如图:

Redis搭建(七):Redis的Cluster集群动态增删节点

   2.2、指定7007节点作为7006的从节点,实现主从的配置。

[root@linux redis]# pwd

[root@linux redis]# /root/application/program/redis/

[root@linux redis]# redis-cli -c -h 192.168.127.130 -p 7007  //登陆7007

192.168.127.130::7007>cluster replicate 71ecd970838e9b400a2a6a15cd30a94ab96203bf(主节点的ID,这里是7006)

192.168.127.130::7007>OK

 效果如图:

 Redis搭建(七):Redis的Cluster集群动态增删节点

三、Cluster集群删除操作

  由于我们在上面的步骤里面创建7006和7007两个主从的节点,下面接下来的操作,我就是从这个Cluster集群模式中动态的删除掉这两个节点。删除的顺序是先删除Slave从节点,然后在删除Master主节点,最后还原到我们上一篇文章建立的Cluster集群模式,也就是3个主节点和3个从节点。现在是4个主节点和4个从节点。效果如图:

Redis搭建(七):Redis的Cluster集群动态增删节点

1、动态删除Slave从服务器节点

       1.1、删除7007从节点,输入del-node命令,指定删除节点的IP地址和Port端口号,同时还要提供该从节点ID名称。

[root@linux redis]# pwd

[root@linux redis]# /root/application/program/redis/

[root@linux redis]# ruby redis-trib.rb del-node 192.168.127.130:7007 991ed242102aaa08873eb9404a18e0618a4e37bd

  删除成功如图:        

  Redis搭建(七):Redis的Cluster集群动态增删节点

  删除前如图:

  Redis搭建(七):Redis的Cluster集群动态增删节点

  删除后如图:

  Redis搭建(七):Redis的Cluster集群动态增删节点

  

2、动态删除Master主服务器节点

  要想删除Master主节点,可能要繁琐一些。因为在Master主节点上有数据槽(slots),为了保证数据的不丢失,必须把这些数据槽迁移到其他Master主节点上,然后在删除主节点。

  

  2.1、重新分片,把要删除的Master主节点的数据槽移动到其他Master主节点上,以免数据丢失。

[root@linux redis]# pwd

[root@linux redis]# /root/application/program/redis/

[root@linux redis]# ruby redis-trib.rb reshard 192.168.127.130:7006

    2.1.1、移除多少槽如图:创建输入200,这里要输入199,因为计数是从0开始的,切记。

         Redis搭建(七):Redis的Cluster集群动态增删节点

     2.1.2、接受槽的Master主节点ID:这个节点可以是任意一个主节点都可以,我选择7002,ID是:3b025b3ecfa65f462de639c7a412be443cf1dd1c

         Redis搭建(七):Redis的Cluster集群动态增删节点

    2.1.3、从哪个主节点移除,该主节点是7006,ID是:71ecd970838e9b400a2a6a15cd30a94ab96203bf

       Redis搭建(七):Redis的Cluster集群动态增删节点

    2.1.4、执行分区计划,选择yes。分区完成,效果如图:

         Redis搭建(七):Redis的Cluster集群动态增删节点

     2.1.5、当前7006主节点已经没有数据槽了。

          Redis搭建(七):Redis的Cluster集群动态增删节点

  2.2、删除7006主节点,提供要删除节点的IP地址和Port端口,当然还有要删除的节点的ID名称。  

[root@linux redis]# pwd

[root@linux redis]# /root/application/program/redis/

[root@linux redis]# ruby redis-trib.rb del-node 192.168.127.130:7006 71ecd970838e9b400a2a6a15cd30a94ab96203bf

    2.2.1、删除成功

             Redis搭建(七):Redis的Cluster集群动态增删节点

     2.2.2、查看节点效果

              Redis搭建(七):Redis的Cluster集群动态增删节点

四、总结

  今天就写到这里了,做一个小小的总结。主从复制和哨兵模式这两个集群模式由于不能动态扩容,而且主节点之间(有多个主节点的情况)数据完全一样,导致了主节点的容量成了整个集群的瓶颈,如果想扩展集群容量,必须扩展主节点的容量。由于以上的问题,redis在3.0开始Cluster集群模式,这个模式在主节点之间数据是不一样的,数据也可以根据需求自动转向其他节点。这样就可以实现横向动态扩容,新增加的主从节点,用于存储新的数据则可,对以前的节点的数据不会有任何影响。再者说,配置也很简单,这才是我们所需要的集群模式。

转自:https://www.cnblogs.com/PatrickLiu/p/8473135.html

Redis搭建(七):Redis的Cluster集群动态增删节点的更多相关文章

  1. Redis进阶实践之十二 Redis的Cluster集群动态扩容

    一.引言     上一篇文章我们一步一步的教大家搭建了Redis的Cluster集群环境,形成了3个主节点和3个从节点的Cluster的环境.当然,大家可以使用 Cluster info 命令查看Cl ...

  2. Redis 超详细自动管理Cluster集群工具上手 redis-trib.rb (多图,手把手)

    安装介绍 ​ redis-trib.rb是一款由Redis官方提供的集群管理工具,能够大量减少集群搭建的时间. ​ 除此之外,还能够简化集群的检查.槽迁徙.负载均衡等常见的运维操作,但是使用前必须要安 ...

  3. redis源码分析(五)--cluster(集群)结构

    Redis集群 Redis支持集群模式,集群中可以存在多个master,每个master又可以拥有多个slave.数据根据关键字映射到不同的slot,每一个master负责一部分的slots,数据被存 ...

  4. CentOS7.6搭建redis4.0.1 cluster集群

    1. 操作系统信息: $ uname -a Linux iZbp11d57wmumnwuihb2czZ -.el7.x86_64 # SMP Fri Feb :: UTC x86_64 x86_64 ...

  5. (转)CentOs7.3 搭建 RabbitMQ 3.6 Cluster 集群服务与使用

    RabbitMQ是一个开源的AMQP实现,服务器端用Erlang语言编写,支持多种客户端,如:Python.Ruby..NET.Java.JMS.C.PHP.ActionScript.XMPP.STO ...

  6. redis cluster集群动态伸缩--删除主从节点

    目标:从集群中剔除一组主从(5007,5008) 经过上一节增加5007,5008主从服务节点后,目前集群的情况是这样的: b3363a81c3c59d57143cd3323481259c044e66 ...

  7. CentOs7.3 搭建 Redis-4.0.1 Cluster 集群服务

    环境 VMware版本号:12.0.0 CentOS版本:CentOS 7.3.1611 三台虚拟机(IP):192.168.252.101,192.168.102..102,192.168.252. ...

  8. redis cluster 集群重新启动关闭

    找遍了redis cluster官方文档,没发现有关集群重新启动和关闭的方法.为啥会没有呢,推測redis cluster至少要三个节点才干执行,三台同一时候挂掉的可能性比較小,仅仅要不同一时候挂掉. ...

  9. Redis Cluster 集群的实现和管理

    系统环境 CentOS 7 集群规划 在一台物理机(实际部署应当分散到多个物理机上),创建6个Redis节点,其中3个主节点.3个从节点. 节点表: IP 端口 主从 路径 192.168.1.21 ...

随机推荐

  1. .net WebApi开发

    1].部署环境.net4及以上版本. [2].vs2010  开发需单独安装vs2010 sp1和mvc4 mvc4:http://www.asp.net/mvc/mvc4 或者 http://dow ...

  2. Oracle 过程控制语句整理

    分支语句/循环语句 v_case ) :; begin then dbms_output.put_line('条件成立'); elsif then then dbms_output.put_line( ...

  3. 【ECSHOP插件】商品颜色尺寸仿淘宝选择功能免费发布

    先放效果图,如此实用的功能是不是迫不及待的要添加到自己的网店中了呢   牵涉到的修改文件(default模板为例) /themes/default/style.css /themes/default/ ...

  4. ecshop支付方式含线下自提

    用户展示页面模板所在:如ecshop/theme/default/flow.dwt 后台管理展示页面模板所在:如admin/templates/payment_list.htm ecshop 支付接口 ...

  5. Python之多线程和多进程

    一.多线程 1.顺序执行单个线程,注意要顺序执行的话,需要用join. #coding=utf-8 from threading import Thread import time def my_co ...

  6. UI(四)之拓扑图创建

    关键函数: 1.LoadMap void CTopology::LoadMap() { //m_map.RemoveAllLayers(); AddLayersBasemap(); //AddLaye ...

  7. Xilinx官网查询各个版本软件的手册

    在Xilinx官网查询各个版本软件的手册需要点击 See All Versions

  8. 怎样将Android SDK源码 导入到Eclipse中?

    在Eclipse中导入android sdk源码 http://blog.csdn.net/hahahacff/article/details/8590649

  9. Android通过xml生成创建View的过程解析

    Android的布局方式有两种,一种是通过xml布局,一种是通过java代码布局,两种布局方式各有各的好处,当然也可以相互混合使用.很多人都习惯用xml布局,那xml布局是如何转换成view的呢?本文 ...

  10. 使用三层交换机实现不同vlan的互通

    如下拓扑图所示,要实现vlan10(192.168.10.0/24)与vlan 20(192.168.20.0/24)的网络互通. 三层交换机配置: 创建vlan:Switch#configure t ...