Redis集群

前言

我们之前已经讲过了哨兵模式,现在我们来学习一下redis的集群配置。请大家耐心仔细的看,因为学会了知识就是你的了,但是学不会,那还是我的,哈哈~

编写配置文件

我们先将之前创建的主从复制用到的配置文件移动到某个文件夹中,或者新建个文件夹,放到里面也可以

#创建文件夹
mkdir conf
#j移动配置文件
mv redis-6*.conf conf/

目录大致上是这样的,如下:
Redis集群_第1张图片
创建集群至少要6个服务,6个服务分别为:6379、6380、6381、6389、6390、6391,我们以6379这个文件内容举例,6379配置文件的内容如下:

include /myredis/redis.conf
pidfile "/myredis/pid/redis_6379.pid"
port 6379
dbfilename "dump6379.rdb"
#密码(如果你设置了requirepass)
masterauth 123456
# 集群配置
cluster-enabled yes
cluster-config-file nodes-6379.conf
cluster-node-timeout 15000

我们将新建好的6379配置文件复制5份,命令如下:

cp redis6379.conf

Redis集群_第2张图片
我们按照端口号顺序,对6380、6381、6389、6390、6391配置文件的内容进行替换,输入以下命令,然后回车,记得保存!!!如下:
Redis集群_第3张图片

rdb持久化文件删除,因为我们要用集群模式重新创建,命令如下:

rm -rf dump*.rdb

Redis集群_第4张图片
我们启动这6个服务,命令如下:

redis-server redis6379.conf

Redis集群_第5张图片
我们进入到我们刚开始将redis下载下来的目录中,然后进入到解压后的目录中,如下:

cd /data/redis-6.2.6/src

我们使用命令,创建集群,命令如下:

# IP地址和端口号是我本机,大家要写自己的IP,别写错
# 我的redis设置密码了,-a后面是密码
redis-cli -a 123456 --cluster create --cluster-replicas 1 192.168.133.128:6379 192.168.133.128:6380 192.168.133.128:6381 192.168.133.128:6389 192.168.133.128:6390 192.168.133.128:6391

Redis集群_第6张图片
注意:16384这个数字,集群中有16384个插槽。

因为redis集群是无中心化配置我们使用客户端进行连接,所以我们连接哪个端口的服务都可以,命令如下:

# -c 的意思就是连接集群
redis-cli -c  -p 6379 -a 123456

登录以后,我们查看节点信息,命令如下:

cluster nodes


集群服务分配原则:
尽量保证每台主库redis、从库redis都在不同服务器上(一台G掉,其他还可以继续使用)

什么是slots?


一个redis集群包含16384个插槽,数据库中的每个键都属于这16384个插槽中的其中一个。
集群使用公示CRC16(key)%16384来计算键 key 属于哪个槽,其中CRC16(key) 语句用于计算key的CRC16校验和。
图中的三个节点分别处理以下范围的插槽:
A服务负责 0号至5460号插槽
B服务负责5461号至10922号插槽
C服务负责10923号至16383号插槽

加入数据,计算插槽值,该值保存在6381的服务中,自动重定向到了6381服务,如下:
Redis集群_第7张图片
查询a键在集群中的插槽值,命令如下:

cluster keyslot 键

Redis集群_第8张图片
查询插槽值的个数,命令如下:

cluster countkeysinslot 插槽值

Redis集群_第9张图片
查询插槽值对应的key,命令如下:

cluster getkeysinslot 插槽值 个数

在这里插入图片描述

故障恢复

我们刚才配置的集群节点超时内容为:

cluster-node-timeout 15000

我们将某台master服务停掉,然后等15秒,再次查看节点信息,如下:
在这里插入图片描述

Redis集群_第10张图片
等待15秒以后,再次查看集群节点信息,如下:
在这里插入图片描述

6379已经G掉了,新的master就是6391,我们将6379启动,然后再查看节点信息,如下:
在这里插入图片描述
Redis集群_第11张图片
如果两次启动后的ID一模一样,那么就不需要那么麻烦了,再次查看节点信息时,只是由master变成了slave而已,如下:
在这里插入图片描述

如果我们发现两个ID不一样了,所以我们要在现有的集群中根据ID删掉它,然后把重新启动后的6379添加进去,如下:

# 在集群中去掉该原6379的ID
cluster forget 30e0dab7f599eed53db06250556482c3cbc6174f

图中标记的slave,意思就是该服务是哪个服务的从服务。
在这里插入图片描述
首先我们将6379服务的dump和nodes配置文件删除,如下:

rm -rf /myredis/dump6379.rdb
rm -rf /myredis/nodes-6379.conf

启动6379服务,命令如下:

redis-server /myredis/redis6379.conf 

我们将刚启动的6379设置为6391的从服务,命令如下:

# ID为集群中某个master节点的ID
redis-cli -a 123456 --cluster add-node --cluster-slave --cluster-master-id 2b0819484c0a25af1d0626f2a7df933c36f4c3ed 192.168.133.128:6379 192.168.133.128:6391


感谢小伙伴们观看!

你可能感兴趣的:(Redis,redis,缓存)