我们之前已经讲过了哨兵模式,现在我们来学习一下redis的集群配置。请大家耐心仔细的看,因为学会了知识就是你的了,但是学不会,那还是我的,哈哈~
我们先将之前创建的主从复制用到的配置文件移动到某个文件夹中,或者新建个文件夹,放到里面也可以
#创建文件夹
mkdir conf
#j移动配置文件
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
redis-server redis6379.conf
我们进入到我们刚开始将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集群是无中心化配置
我们使用客户端进行连接,所以我们连接哪个端口的服务都可以,命令如下:
# -c 的意思就是连接集群
redis-cli -c -p 6379 -a 123456
登录以后,我们查看节点信息,命令如下:
cluster nodes
集群服务分配原则:
尽量保证每台主库redis、从库redis都在不同服务器上(一台G掉,其他还可以继续使用)
一个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 插槽值
cluster getkeysinslot 插槽值 个数
我们刚才配置的集群节点超时内容为:
cluster-node-timeout 15000
我们将某台master服务停掉,然后等15
秒,再次查看节点信息,如下:
6379已经G掉了,新的master
就是6391
,我们将6379启动,然后再查看节点信息,如下:
如果两次启动后的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