1 集群的概念
主从: 数据备份, 即把一份数据多备份在几台从服务器上
集群: 数据分片, 即把一堆数据分在多个数据库上存储
集群是一组相互独立的、通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理。
一个客户与集群相互作用时,集群像是一个独立的服务器
集群配置是用于提高可用性和可缩放性
当请求到来首先由负载均衡服务器处理,把请求转发到另外的一台服务器上
2 Redis集群
(1) 软件层面
(2) 硬件层面
有多台电脑, 每台电脑上都启动了一个或多个redis服务
3 搭建集群
(1) 准备集群的配置文件
只需要改bind的IP为自己服务器的IP
把这几个文件拷贝到虚拟机中
(2) 创建集群
安装ruby环境, 因为redis-trib.rb是用ruby开发的
sudo apt-get install ruby
redis的安装包中包含了redis-trib.rb,⽤于创建集群, 将命令复制, 这样可以在任何⽬录下调⽤此命令
sudo cp /usr/local/redis/src/redis-trib.rb /usr/local/bin/
运行如下命令运行6个redis服务端
sudo redis-server 7000.conf
…
可以看到6个服务端已经运行
- 运行如下命令, 创建集群
replicas 后面的数字1代表为每一个主节点创建一个从节点,
以下命令就是让redis-trib
程序创建一个包含三个主节点和三个从节点的集群
redis-trib.rb create —replicas 1 192.168.3.67:7000 192.168.3.67:7001 192.168.3.67:7002 192.168.3.67:7003 192.168.3.67:7004 192.168.3.67:7005
执行上述指令时报错, 主要原因是安装的 ruby 不是最新版本!
查看自己的gem源, 发现是https://rubygems.org/ 就需要更换
更换指令为
gem sources —add https://gems.ruby-china.com/ —remove https://rubygems.org/
通过 gem 安装 redis 的相关依赖
sudo gem install redis
然后重新执⾏指令
redis-trib.rb create —replicas 1 192.168.3.67:7000 192.168.3.67:7001 192.168.3.67:7002 192.168.3.67:7003 192.168.3.67:7004 192.168.3.67:7005
(3) 测试集群
- redis客户端连接集群
redis-cli -h 192.168.3.67 -p 7000 -c
4 集群的设计
(1) 在哪个master节点写数据
- redis cluster在设计的时候,就考虑到了去中⼼化,去中间件,也就是说,集群中 的每个节点都是平等的关系,都是对等的,每个节点都保存各⾃的数据和整个集 群的状态。每个节点都和其他所有节点连接,⽽且这些连接保持活跃,这样就保 证了我们只需要连接集群中的任意⼀个节点,就可以获取到其他节点的数据
- Redis集群没有并使⽤传统的⼀致性哈希来分配数据,⽽是采⽤另外⼀种叫做哈希 槽 (hash slot)的⽅式来分配的。redis cluster 默认分配了 16384 个slot,当我们 set⼀个key 时,会⽤CRC16算法来取模得到所属的slot,然后将这个key 分到哈 希槽区间的节点上,具体算法就是:CRC16(key) % 16384。所以我们在测试的 时候看到set 和 get 的时候,直接跳转到了7000端⼝的节点
- Redis 集群会把数据存在⼀个 master 节点,然后在这个 master 和其对应的slave 之间进⾏数据同步。当读取数据时,也根据⼀致性哈希算法到对应的 master 节 点获取数据。只有当⼀个master 挂掉之后,才会启动⼀个对应的 slave 节点,充当 master
- 需要注意的是:必须要3个或以上的主节点,否则在创建集群时会失败,并且当存 活的主节点数⼩于总节点数的⼀半时,整个集群就⽆法提供服务了