要想搭建一个最简单的Redis集群,那么至少须要6个节点:3个Master和3个Slave。为何须要3个Master呢?若是你了解过Hadoop/Storm/Zookeeper这些的话,你就会明白通常分布式要求基数个节点,这样便于选举(少数服从多数的原则)。node
这里,我将采用一种“偷懒”的方式,在一个Linux虚拟机上搭建6个节点的Redis集群。(由于开启6个Linux虚拟机,个人电脑彻底扛不住)redis
实际上,思路很简单,我将在一台节点上开启6个Redis实例,而且这6个Redis各自有本身的端口。这样的话,至关于模拟出了6台机器了。而后在以这6个实例组建Redis集群就能够了。ruby
第一步:为这6个实例建立好各自存放的目录分布式
第二步:既然是要启动6个Redis实例,天然须要准备各自的配置文件oop
具体来讲,须要注意下:因为在一台机器(192.168.99.121)上,所以每一个实例应该有不一样的端口;同时,每一个实例显然会有本身的存放数据的地方;开启AOF模式;开启集群配置;开启后台模式;3d
第三步:实际上,Redis集群的操做在后文你能够看到是经过Ruby脚原本完成的,所以咱们须要安装Ruby相关的RPM包,以及Redis和Ruby的接口包。orm
第四步:让Redis集群工做起来!cdn
接下来,咱们要经过Ruby脚原本建立集群了。blog
[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接口
首先,咱们来看一下建立集群命令中 --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集群搭建是否成功
到这里,Redis集群的搭建就完毕了,See U~