Redis系列(五): Redis 集群搭建!

末蓝、 2022-11-29 11:18 198阅读 0赞

前言

上篇文章我们介绍了 Redis 集群的工作原理机制,本文我们就来手动搭建一个 Redis 集群玩玩。强烈建议大家在开始本篇文章之前先看看上篇文章的介绍,这样对集群的安装会更加清楚一些。Redis 集群工作原理

环境及版本说明

  • 环境:MacOS 10.14.6
  • Redis 版本:Redis-4.0.10

最终目标

  • 集群最终会有 6 个节点,3 主 3 从
  • 7000 - 7002 三个节点为主节点
  • 7003 - 7003 三个节点为从节点
  • 7000 对应的从节点为 7003,7001 对应的从节点为 7004, 7002 对应的从节点为 7005。

集群搭建及验证

  1. 创建一个目录,并在该目录下创建 6 个子文件夹,用于存放集群文件。

format_png


  1. 修改减压好的 Redis 的 redis.conf 文件

format_png 1


  1. copy Redis 减压好的目录到 6 个节点下,并在每个节点下修改端口号,然后启动,以节点 1 为例

format_png 2

6 个节点正常启动后,应该可以看到如下图所示效果。format_png 3

到此,我们要组建集群的 6 个节点已经全部完成启动,接下来我们要做三件事,第一件事就是把这些节点全部连接起来(为什么要将节点连接起来及建连发生的事情,参看上篇文章:Redis 集群工作原理),第二件事情是将 16384 个槽分配给其中三个主节点,第三件事就是把其中一部分节点的身份改成从节点身份(因为默认启动起来的节点的身份都是主节点)


  1. 将启动的各个节点进行连接操作,我们这里在节点 1 上操作

format_png 4


  1. 分配槽,我们这里选择端口为 7000、7001、7002 的节点作为主节点,7003、7004、7005 为丛节点

format_png 5

注意: 这里不能通过 redis-cli 登录上去执行,否则会报如下错误:format_png 6

槽分配完成以后,正常情况下我们可以看到如下图所示的信息,从信息中我们可以看出 cluster_state:ok,该信息表示 Redis 集群现在已经可以正常工作了。

format_png 7

format_png 8

我们在来看看刚刚槽分配的情况,执行一下命令查看,通过截图可以看出,16384 个槽按照预期被分配到了 7001、7002、7003 端口对应的节点上了。

format_png 9

format_png 10


  1. 到此,整个集群的主节点已经全部配置好了,并且集群的工作状态也是 ok 的,接下来将 7003、7004、7005 三个端口对应的节点的身份变成从节点。我们将 7003 节点作为 7000 节点的从节点,7004 节点作为 7001 节点的从节点,7005 节点作为 7002 节点的从节点。执行如下命令:

format_png 11

执行完以上节点命令后,我们在来看看当前集群的状态,如下图所示:

format_png 9

format_png 12

此时我们可以看到,如预期所示,7000 - 7002 三个节点的身份为主节点,7003 - 7005 三个节点的身份为从节点。

到此我们的集群搭建也就基本问完成了,简单吧,下面我们来看看上篇文章提到的转向到底是怎么回事。

执行如下命令,出现Moved错误,我们也可以在以执行src/redic-cli -h 127.0.0.1 -p 7000 -c 登录,这时候会直接重定向到目标节点执行。

format_png 13

总结

到此,我们通过实践的方式验证了我们上篇文章得出的结论,后续文章我们也尽量以这种方式来进行论证。

发表评论

表情:
评论列表 (有 0 条评论,198人围观)

还没有评论,来说两句吧...

相关阅读

    相关 redis

    文章来自博客园,稍加补充,如侵权,请联系删除 初学redis,学习了redis的常用数据结构,然后就到了学习redis集群的时候了 那么,学习前面应该先搭建起来redis集

    相关 Redis--

    集群概述 redis是一个开源的key value存储系统,受到了广大互联网公司的青睐。redis3.0版本之前只支持单例模式,在3.0版本及以后才支持集群,我这里