这是redis集群介绍的上篇,主要是关于Redis集群的搭建。后续将为大家介绍Redis集群的常用命令、Java操作Redis集群、以及与Spring/Spring MVC的整合等知识。
Redis集群搭建
要想搭建一个最简单的Redis集群,那么至少需要6个节点:3个Master和3个Slave。为什么需要3个Master呢?如果你了解过Hadoop/Storm/Zookeeper这些的话,你就会明白一般分布式要求基数个节点,这样便于选举(少数服从多数的原则)。
![](https://i-blog.csdnimg.cn/blog_migrate/489b15c15549c56c6c0f5bdc1ac9deab.webp?x-image-process=image/format,png)
这里,我将采用一种“偷懒”的方式,在一个Linux虚拟机上搭建6个节点的Redis集群。(因为开启6个Linux虚拟机,我的电脑完全扛不住)
实际上,思路很简单,我将在一台节点上开启6个Redis实例,并且这6个Redis各自有自己的端口。这样的话,相当于模拟出了6台机器了。然后在以这6个实例组建Redis集群就可以了。
第一步:为这6个实例创建好各自存放的目录
![](https://i-blog.csdnimg.cn/blog_migrate/a3a6efbd409aaab6da935b9a681d6639.webp?x-image-process=image/format,png)
第二步:既然是要启动6个Redis实例,自然需要准备各自的配置文件
![](https://i-blog.csdnimg.cn/blog_migrate/bbb10b05618c04cb06f8c996bebe9edb.webp?x-image-process=image/format,png)
![](https://i-blog.csdnimg.cn/blog_migrate/2b900ddd22d36f4242b0c3c68212c6a6.webp?x-image-process=image/format,png)
具体来说,需要注意下:由于在一台机器(192.168.99.121)上,因此每个实例应该有不同的端口;同时,每个实例显然会有自己的存放数据的地方;开启AOF模式;开启集群配置;开启后台模式;
第三步:实际上,Redis集群的操作在后文你可以看到是通过Ruby脚本来完成的,因此我们需要安装Ruby相关的RPM包,以及Redis和Ruby的接口包。
![](https://i-blog.csdnimg.cn/blog_migrate/c920e3f15de55444e446b4002d6fbb3e.webp?x-image-process=image/format,png)
![](https://i-blog.csdnimg.cn/blog_migrate/978b5ab9235217e830fa50c9093ad279.webp?x-image-process=image/format,png)
![](https://i-blog.csdnimg.cn/blog_migrate/72ce3757f96389749ff941f825aa55be.webp?x-image-process=image/format,png)
第四步:让Redis集群工作起来!
![](https://i-blog.csdnimg.cn/blog_migrate/59dfca38e29b4884081f44060b333e94.webp?x-image-process=image/format,png)
接下来,我们要通过Ruby脚本来创建集群了。
![](https://i-blog.csdnimg.cn/blog_migrate/be161c37462c1acf572c2980e3494063.webp?x-image-process=image/format,png)
[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
![](https://i-blog.csdnimg.cn/blog_migrate/a04efeefae8fdc4a316246841e2cfd85.webp?x-image-process=image/format,png)
![](https://i-blog.csdnimg.cn/blog_migrate/f67e0b2342dcc63d8df8b88307a15c0e.webp?x-image-process=image/format,png)
首先,我们来看一下创建集群命令中 --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集群搭建是否成功
![](https://i-blog.csdnimg.cn/blog_migrate/cf1f3b70c67ca550ee1e11a43ab1dbd5.webp?x-image-process=image/format,png)
![](https://i-blog.csdnimg.cn/blog_migrate/2abaa65670b7c8550cd3c1b3e8c2ea20.webp?x-image-process=image/format,png)