引用:http://www.cnblogs.com/zhaoguihua/p/redis-005.html
集群要实现的目的是要将不同的 key 分散放置到不同的 redis 节点,这里我们需要一个规则或者算法,通常的做法是获取 key 的哈希值,然后根据节点数来求模,但这种做法有其明显的弊端,当我们需要增加或减少一个节点时,会造成大量的 key 无法命中,这种比例是相当高的,所以就有人提出了一致性哈希的概念。
一致性哈希有四个重要特征:
均衡性:也有人把它定义为平衡性,是指哈希的结果能够尽可能分布到所有的节点中去,这样可以有效的利用每个节点上的资源。
单调性:对于单调性有很多翻译让我非常的不解,而我想要的是当节点数量变化时哈希的结果应尽可能的保护已分配的内容不会被重新分派到新的节点。
但一致性哈希不是我们今天要介绍的重点,因为 Redis 引入另一种哈希槽(hash slot)的概念。
Redis 集群中内置了 16384 个哈希槽,当需要在 Redis 集群中放置一个 key-value 时,redis 先对 key 使用 crc16 算法算出一个结果,然后把结果对 16384 求余数,这样每个 key 都会对应一个编号在 0-16383 之间的哈希槽,redis 会根据节点数量大致均等的将哈希槽映射到不同的节点。
使用哈希槽的好处就在于可以方便的添加或移除节点。
当需要增加节点时,只需要把其他节点的某些哈希槽挪到新节点就可以了;
当需要移除节点时,只需要把移除节点上的哈希槽挪到其他节点就行了。
下面开始搭建环境,
1、先创建3个目录:9001、9002、9003,目录名即是redis实例的端口号:
2、然后把 redis-server、redis.conf这两个文件分别拷贝到这三个目录里面:
3、打开redis.conf文件,文件中只配置一下内容:
daemonize yes
port 9001
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes
其余两个redis实例的端口分别修改为9002、9003。
4、分别进入这3个目录并启动这3个实例:
5、接下来使用下列命令创建集群:
./redis-trib.rb create --replicas 0 127.0.0.1:9001 127.0.0.1:9002 127.0.0.1:9003
5.1 报以下错误:
因为是执行的ruby的脚本,需要ruby的环境,安装命令:
yum install ruby
5.2 再执行第6步的创建集群命令,还会报错,提示缺少rubygems组件,使用yum安装:
安装rubygems:
5.3 再执行第6步的创建集群命令,还会报错,提示不能加载redis,是因为缺少redis和ruby的接口,使用gem 安装:
安装redis:
gem install redis --version 3.0.0
注意:gem install redis --version 3.0.0 失败的话,需要修改一下gem的源
gem sources --remove https://rubygems.org/
gem sources -a https://ruby.taobao.org/
5.4 再次执行第6步的命令,正常执行:
redis集群环境搭建成功。