一.集群的搭建

1.准备工作

  (1)安装ruby环境

    redis集群管理工具redis-trib.rb依赖ruby环境,首先需要安装ruby环境:

      yum -y install ruby

      yum -y install rubygems

  (2)安装ruby和redis的接口程序

    拷贝redis-3.0.0.gem至/usr/local下;

    执行安装:

      gem install /usr/local/redis-3.0.0.gem

2.集群规划

  (1)Redis集群最少需要6个节点,可以分布在一台或者多台主机上。在教案在一台主机上创建伪分布式集群,不同的端口表示不同的redis节点,如下:

    主节点:192.168.56.3:7001 192.168.56.3:7002 192.168.56.3:7003

    从节点:192.168.56.3:7004 192.168.56.3:7005 192.168.56.3:7006

  (2)在/usr/local/redis下创建redis-cluster目录,其下创建7001、7002。。7006目录,如下:

  (3)将redis解压路径下的配置文件redis.conf,依次拷贝到每个700X目录内,并修改每个700X目录下的redis.conf配置文件:

    port 700X

    bind 192.168.56.3

    cluster-enabled yes

    建议配置:开启后台模式  daemonized  yes

    指定日志输出的文件    logfile  /usr/local/redis/redis-cluster/7001/node1.log

3.启动每个结点redis服务

  依次以700X下的redis.conf,启动redis节点。(必须指定redis.conf文件)

  ./redis-server /../700X/redis.conf

 

4.执行创建集群命令

  进入到redis源码存放目录/home/redis/redis-4.10.3/src下,执行redis-trib.rb,此脚本是ruby脚本,它依赖ruby环境。

./redis-trib.rb create --replicas 1 192.168.4.253:7001 192.168.4.253:7002 192.168.4.253:7003 192.168.4.253:7004 192.168.4.253:7005  192.168.4.253:7006

5.查询集群信息

  集群创建成功登陆任意redis结点查询集群中的节点情况。

  ./redis-cli -c -h 192.168.56.3 -p 7001

  说明:

    ./redis-cli -c -h 192.168.56.3 -p 7001 ,其中:

    -c表示以集群方式连接redis,

    -h指定ip地址,

    -p指定端口号

    cluster nodes 查询集群结点信息;

    cluster info 查询集群状态信。

二.添加主节点

1.节点规划

   集群创建成功后可以向集群中添加节点,下面是添加一个master主节点

   添加7007节点,参考集群结点规划章节添加一个“7007”目录作为新节点。

   添加节点,执行下边命令:

   ./redis-trib.rb add-node  192.168.23.20:7007 192.168.23.20:7001

  查看集群结点发现7007已添加到集群中:

2.hash槽重新分配

  添加完新的主节点后,需要对主节点进行hash槽分配,这样该主节才可以存储数据。

  redis集群有16384个槽,被所有的主节点共同分配,通过查看集群结点可以看到槽占用情况。

  给刚添加的7007结点分配槽:

  第一步:连接上集群

  ./redis-trib.rb reshard 192.168.23.20:7001(连接集群中任意一个可用节点都行)

  第二步:输入要分配的槽数量

  输入 500表示要分配500个槽

  第三步:输入接收槽的结点id

  这里准备给7007分配槽,通过cluster nodes查看7007结点id为79bbb30bba66b4997b9360dd09849c67d2d02bb9

  输入:79bbb30bba66b4997b9360dd09849c67d2d02bb9

  第四步:输入源结点id

  这里输入all

  第五步:输入yes开始移动槽到目标结点id

3.添加从节点

  集群创建成功后可以向集群中添加节点,下面是添加一个slave从节点。

  添加7008从结点,将7008作为7007的从结点。

新增从节点命令格式:

     ./redis-trib.rb add-node --slave --master-id masterID newNodIP:port MasterIP:port

    masterID       主节点id,从cluster  nodes信息中查看

    newNodIP:port     新增节点的ip:端口

    MasterIP:port        主节点的ip:端口

  执行如下命令:

    ./redis-trib.rb add-node --slave --master-id 909c349f5f2d4db015101fb7c4e3c227a74ad382 192.168.4.253:7008 192.168.4.253:7007

    79bbb30bba66b4997b9360dd09849c67d2d02bb9  是7007结点的id,可通过cluster nodes查看。

  注意:

    如果原来该结点在集群中的配置信息已经生成cluster-config-file指定的配置文件中(如果cluster-config-file没有指定则默认为nodes.conf),这时可能会报错:

    [ERR] Node XXXXXX is not empty. Either the node already knows other nodes (check with CLUSTER NODES) or contains some key in database 0

    解决方法:

    删除生成的配置文件nodes.conf,删除后再执行./redis-trib.rb add-node指令。

  查看集群中的结点,刚添加的7008为7007的从节点:

4.删除结点

  删除节点命令格式:

  ./redis-trib.rb del-node nodeIP:port nodeID

  nodeIP:port    待删除节点的ip:端口

  nodeID             待删除节点的id,从cluster node中查看

  删除已经占有hash槽的结点会失败,报错如下:

  [ERR] Node 127.0.0.1:7005 is not empty! Reshard data away and try again.

  需要将该结点占用的hash槽分配出去(参考hash槽重新分配)。

Redis的集群搭建的更多相关文章

  1. Redis本地集群搭建(5版本以上)

    Redis本地集群搭建(5版本以上) 2019年11月3日10:05:48 步骤 1.下载安装Redis的安装包 2.复制5份,一共6份Redis的解压安装版,修改每个Redis节点的端口并开启节点 ...

  2. redis的集群搭建(很详细很详细)

    说在前面的话 之前有一节说了redis单机版的搭建和使用jedis管理redis单机版和集群版, 本节主要讲一下redis的集群搭建. 跳转到jedis管理redis的使用 认识redis集群 首先我 ...

  3. linux环境下redis安装(redis伪集群搭建)

    redis在linux环境下搭建 1.创建目录 [root@192 local]# mkdir /usr/local/redis 2.下载redis,并解压 [root@192 local]# wge ...

  4. Redis Cluster集群搭建与配置

    Redis Cluster是一种服务器sharding分片技术,关于Redis的集群方案应该怎么做,请参考我的另一篇博客http://www.cnblogs.com/xckk/p/6134655.ht ...

  5. Redis Cluster集群搭建与应用

    1.redis-cluster设计 Redis集群搭建的方式有多种,例如使用zookeeper,但从redis 3.0之后版本支持redis-cluster集群,redis-cluster采用无中心结 ...

  6. Redis笔记-集群搭建

    Redis单机版搭建上一篇已经基本介绍了,下面讨论Redis集群搭建方案和示例. 1.关于Redis常用的集群方案(三种): a.一主多从,如一个Master.两个Slave b.薪火相传,即集群中的 ...

  7. Redis的搭建和Redis的集群搭建

    1.Redis的官网:https://redis.io/      Redis的测试网站:http://try.redis.io/ 2.参考博客:https://www.cnblogs.com/maf ...

  8. 【Redis】Redis cluster集群搭建

    Redis集群基本介绍 Redis 集群是一个可以在多个 Redis 节点之间进行数据共享的设施installation. Redis 集群不支持那些需要同时处理多个键的 Redis 命令, 因为执行 ...

  9. redis主从集群搭建及容灾部署(哨兵sentinel)

    Redis也用了一段时间了,记录一下相关集群搭建及配置详解,方便后续使用查阅. 提纲 Redis安装 整体架构 Redis主从结构搭建 Redis容灾部署(哨兵sentinel) Redis常见问题 ...

  10. Redis Cluster集群搭建<原>

    一.环境配置 一台window 7上安装虚拟机,虚拟机中安装的是centos系统. 二.目标     Redis集群搭建的方式有多种,根据集群逻辑的位置,大致可以分为三大类:基于客户端分片的Redis ...

随机推荐

  1. Java基础系列--07_Object类的学习及源码分析

    Object: 超类 (1)Object是类层次结构的顶层类,是所有类的根类,超类.   所有的类都直接或者间接的继承自Object类.   所有对象(包括数组)都实现这个类的方法 (2)Object ...

  2. C#行转列&绑定DGV

    c#行转列 今天工作中,恰好写到此处,想起之前第一次行转列的时候,卡壳了好久,今天正好碰上,故而花费几分钟,整理成案例,分享到博客上. 这是个很简单的功能,第一次可以使用案例,后面最好能达到信手拈来的 ...

  3. 服务消费者Feign和Ribbon的区别

    1.Ribbon通过注解@EnableEurekaClient/@EnableDiscoveryClient向服务中心注册:    PS:选用的注册中心是eureka,那么就推荐@EnableEure ...

  4. Linux:Day17(下) openssl

    Linux Services and Security OpenSSL OpenSSH dns:bind web:http,httpd(apache),php,mariadb(mysql) lamp ...

  5. (n)e(m)

    经常会看到类似于 1e30 9e5 类似的表达式 (我一个蒟蒻不懂啊) 于是 给自己解释解释 那么 nem就是 n乘以10的m次方 (哈哈哈哈,我简直是太弱了)

  6. 最新版jQuery v3.3.1的BUG以及解决办法(什么问题不重要,怎么解决问题才重要)

    发现问题 最新版的 FineUIPro v5.2.0 中,我们将内置的 jQuery v1.12.4 升级到 jQuery v3.3.1 ,可以看升级记录: +升级到jQuery v3.3.1.    ...

  7. 随心测试_数据库_002 <数据库系统组成>

    软测工程师:作为综合运用多学科知识,保障软件质量的重要岗位.需要我们学以致用,在工作中不断学习提升.以下:软测人员必备_数据库核心技能学习点,供大家学习参考. 数据库系统组成_必备 1. 简介:数据库 ...

  8. 以API方式调用C# dll,使用OneNote2013 sp1实现OCR识别本地图片

    http://www.cnblogs.com/Charltsing/p/OneNoteOCRAPI.html OneNote2013 OCR API调用使用说明2019.4.17 使用说明:1.安装干 ...

  9. Python之路【第十七篇】:Django【进阶篇 】(转自银角大王博客)

    Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去调用数据访问层执行 ...

  10. golang核心Goroutine和channel

    一.Goroutine 1.介绍 goroutine简介 goroutine是go语言中最为NB的设计,也是其魅力所在,goroutine的本质是协程,是实现并行计算的核心.goroutine使用方式 ...