1 集群的概念

主从: 数据备份, 即把一份数据多备份在几台从服务器上
集群: 数据分片, 即把一堆数据分在多个数据库上存储

集群是一组相互独立的、通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理。
一个客户与集群相互作用时,集群像是一个独立的服务器
集群配置是用于提高可用性和可缩放性
当请求到来首先由负载均衡服务器处理,把请求转发到另外的一台服务器上
image.png

2 Redis集群

(1) 软件层面

只有一台电脑, 在这台电脑上启动了多个redis服务
image.png

(2) 硬件层面

有多台电脑, 每台电脑上都启动了一个或多个redis服务
image.png

3 搭建集群

(1) 准备集群的配置文件

image.png
只需要改bind的IP为自己服务器的IP
image.png
把这几个文件拷贝到虚拟机中
image.png

(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

image.png
可以看到6个服务端已经运行
image.png

  • 运行如下命令, 创建集群

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 不是最新版本!
image.png
查看自己的gem源, 发现是https://rubygems.org/ 就需要更换
image.png
更换指令为

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

成功
image.png
image.png

(3) 测试集群

  • redis客户端连接集群

    redis-cli -h 192.168.3.67 -p 7000 -c

image.png

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个或以上的主节点,否则在创建集群时会失败,并且当存 活的主节点数⼩于总节点数的⼀半时,整个集群就⽆法提供服务了

image.png