搭建Redis分片集群

说明:单体Redis有许多问题,可通过Redis数据持久化、搭建主从集群、哨兵和Redis分片集群解决单体Redis数据丢失、高并发、数据恢复和海量数据存储的问题。前三个参考http://t.csdn.cn/6pp2F、http://t.csdn.cn/o9u0S,本问介绍如何创建Redis分片集群。

结构图

在这里插入图片描述

创建

如上图所示,创建六个Redis实例,三个master(端口分别为:7001、7002、7003),三个slave(端口分别为:8001、8002、8003)

第一步:创建目录

切换到/tmp/essay目录下,创建六个文件夹,文件夹名为端口号

mkdir 7001 7002 7003 8001 8002 8003

在这里插入图片描述

第二步:创建配置文件

在当前目录下创建redis.conf文件,内容如下,注意需要修改对应的IP地址和路径

port 6379
# 开启集群功能
cluster-enabled yes
# 集群的配置文件名称,不需要我们创建,由redis自己维护
cluster-config-file /tmp/essay/6379/nodes.conf
# 节点心跳失败的超时时间
cluster-node-timeout 5000
# 持久化文件存放目录
dir /tmp/essay/6379
# 绑定地址
bind 0.0.0.0
# 让redis后台运行
daemonize yes
# 注册的实例ip
replica-announce-ip IP地址
# 保护模式
protected-mode no
# 数据库数量
databases 1
# 日志
logfile /tmp/essay/6379/run.log

在这里插入图片描述

第三步:拷贝配置文件

将配置文件拷贝到各个目录下

echo 7001 7002 7003 8001 8002 8003 | xargs -t -n 1 cp redis.conf

在这里插入图片描述

第四步:修改对应配置

将各个文件夹内配置内容中的6379修改为对应的端口;

printf '%s\n' 7001 7002 7003 8001 8002 8003 | xargs -I{
    
    } -t sed -i 's/6379/{}/g' {
    
    }/redis.conf

在这里插入图片描述

第五步:启动

启动所有redis

printf '%s\n' 7001 7002 7003 8001 8002 8003 | xargs -I{
    
    } -t redis-server {
    
    }/redis.conf

在这里插入图片描述

查看进程状态,可以看到redis服务已经全部打开

在这里插入图片描述

第六步:集群关联

输入以下命令(需要redis5.0以后才可以),建立关系,7001-7003为master,8001-8003为前面对应的slave;

redis-cli --cluster create --cluster-replicas 1 IP地址:7001 IP地址:7002 IP地址:7003 IP地址:8001 IP地址:8002 IP地址:8003

敲“yes”,继续

在这里插入图片描述

完成

在这里插入图片描述

第七步:测试

输入下面的命令,查看集群状态

redis-cli -p 7001 cluster nodes

可以看到分片集群已经搭建成功,master节点后面有卡槽范围,一个节点分别有5461个卡槽

在这里插入图片描述

进入7001Redis客户端操作,需要注意集群操作需要加-c

redis-cli -c -p 7001

随便添加两个值,可以看到前面的端口号发生了变化,说明数据随机存储在三个master对应的卡槽中,这样就解决了海量数据的存储问题。

在这里插入图片描述

总结

通过搭建Redis分片集群,可解决单机Redis的海量数据存储问题。另外,Redis分片集群是Redis集群演变的最终形态,Redis分片集群同样具备主从集群结构、Redis哨兵结构所拥有的优点,就是说Redis分片集群可以完全解决Redis单机的“四大问题”。

猜你喜欢

转载自blog.csdn.net/qq_42108331/article/details/131789039