玩转Redis集群(上)

作者: 张丰哲 | 来源:发表于2017-02-28 23:36 被阅读2427次

    这是redis集群介绍的上篇,主要是关于Redis集群的搭建。后续将为大家介绍Redis集群的常用命令、Java操作Redis集群、以及与Spring/Spring MVC的整合等知识。

    Redis集群搭建

    要想搭建一个最简单的Redis集群,那么至少需要6个节点:3个Master和3个Slave。为什么需要3个Master呢?如果你了解过Hadoop/Storm/Zookeeper这些的话,你就会明白一般分布式要求基数个节点,这样便于选举(少数服从多数的原则)。

    Redis集群模型

    这里,我将采用一种“偷懒”的方式,在一个Linux虚拟机上搭建6个节点的Redis集群。(因为开启6个Linux虚拟机,我的电脑完全扛不住)

    实际上,思路很简单,我将在一台节点上开启6个Redis实例,并且这6个Redis各自有自己的端口。这样的话,相当于模拟出了6台机器了。然后在以这6个实例组建Redis集群就可以了。

    第一步:为这6个实例创建好各自存放的目录

    想一想,为什么要这样做呢?

    第二步:既然是要启动6个Redis实例,自然需要准备各自的配置文件

    拷贝redis.conf 6份 6个Redis实例的具体配置

    具体来说,需要注意下:由于在一台机器(192.168.99.121)上,因此每个实例应该有不同的端口;同时,每个实例显然会有自己的存放数据的地方;开启AOF模式;开启集群配置;开启后台模式;

    第三步:实际上,Redis集群的操作在后文你可以看到是通过Ruby脚本来完成的,因此我们需要安装Ruby相关的RPM包,以及Redis和Ruby的接口包。

    yum install ruby yum install rubygems gem install redis

    第四步:让Redis集群工作起来!

    启动6个Redis实例

    接下来,我们要通过Ruby脚本来创建集群了。

    redis-trib.rb是操作Redis集群的脚本

    [root@mydream121 bin]# ./redis-trib.rb create --replicas 1 192.168.99.121:8001 192.168.99.121:8002 192.168.99.121:8003 192.168.99.121:8004 192.168.99.121:8005 192.168.99.121:8006

    create redis cluster redis cluster info

    首先,我们来看一下创建集群命令中 --replicas 1,这个代表什么意思呢?1其实代表的是一个比例,就是主节点数/从节点数的比例。那么想一想,在创建集群的时候,哪些节点是主节点呢?哪些节点是从节点呢?答案是将按照命令中IP:PORT的顺序,先是3个主节点,然后是3个从节点。这一点可以通过上面的2张图片印证。

    其次,注意到图中slot的概念。slot对于Redis集群而言,就是一个存放数据的地方,就是一个槽。对于每一个Master而言,会存在一个slot的范围,而Slave则没有。在Redis集群中,依然是Master可以读、写,而Slave只读。数据的写入,实际上是分布的存储在slot中,这和以前1.X的主从模式是不一样的(主从模式下Master/Slave数据存储是完全一致的),因为Redis集群中3台Master的数据存储并不一样。这一点将在后续的实验中得到验证。

    第五步:验证Redis集群搭建是否成功

    cluster info/cluster nodes 搭建起来的Redis集群


    到这里,Redis集群的搭建就完毕了,See U~

    相关文章

      网友评论

      • 266c7b31c70f:你就会明白一般分布式要求基数个节点 基数 是 奇数吧 :smile:
        张丰哲:恩恩,同学,谢谢指出~:smile:

      本文标题:玩转Redis集群(上)

      本文链接:https://www.haomeiwen.com/subject/kastgttx.html