前言
我们之前已经讲过了哨兵模式,现在我们来学习一下redis的集群配置。请大家耐心仔细的看,因为学会了知识就是你的了,但是学不会,那还是我的,哈哈~
编写配置文件
我们先将之前创建的主从复制用到的配置文件移动到某个文件夹中,或者新建个文件夹,放到里面也可以
mkdir conf
mv redis-6*.conf conf/
目录大致上是这样的,如下: 创建集群至少要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
我们按照端口号顺序,对6380、6381、6389、6390、6391 配置文件的内容进行替换,输入以下命令,然后回车 ,记得保存!!! 如下:
将rdb 持久化文件删除,因为我们要用集群模式重新创建,命令如下:
rm -rf dump*.rdb
我们启动这6个服务,命令如下:
redis-server redis6379.conf
我们进入到我们刚开始将redis下载下来的目录中,然后进入到解压后的目录中,如下:
cd /data/redis-6.2.6/src
我们使用命令,创建集群,命令如下:
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
注意:16384 这个数字,集群中有16384个插槽。
因为redis集群是无中心化配置 我们使用客户端进行连接,所以我们连接哪个端口的服务都可以,命令如下:
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服务 ,如下: 查询a键在集群中的插槽值,命令如下:
cluster keyslot 键
查询插槽值的个数,命令如下:
cluster countkeysinslot 插槽值
查询插槽值对应的key,命令如下:
cluster getkeysinslot 插槽值 个数
故障恢复
我们刚才配置的集群节点超时内容为:
cluster-node-timeout 15000
我们将某台master服务停掉,然后等15 秒,再次查看节点信息,如下:
等待15秒以后,再次查看集群节点信息,如下:
6379已经G掉了,新的master 就是6391 ,我们将6379启动,然后再查看节点信息,如下: 如果两次启动后的ID一模一样,那么就不需要那么麻烦了,再次查看节点信息时,只是由master变成了slave而已, 如下:
如果我们发现两个ID不一样了,所以我们要在现有的集群中根据ID删掉它,然后把重新启动后的6379添加进去,如下:
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的从服务,命令如下:
redis-cli -a 123456 --cluster add-node --cluster-slave --cluster-master-id 2b0819484c0a25af1d0626f2a7df933c36f4c3ed 192.168.133.128:6379 192.168.133.128:6391
感谢小伙伴们观看!
|