redis的集群分为三种,分别是主从集群,哨兵集群和分片集群
这篇为大家带来如何快速在docker中搭建redis分片集群
一、首先我们先明确主从集群的结构图
二、 我们是在同一台虚拟机中开启6个redis实例,模拟分片集群
三、在docker环境中,创建文件夹
# 进入/tmp目录
cd /tmp
# 删除旧的,避免配置干扰
rm -rf 7001 7002 7003
# 创建目录
mkdir 7001 7002 7003 8001 8002 8003
四、在 /tmp下准备一个新的redis.conf文件,内容如下:
vi redis.conf
port 6379
# 开启集群功能
cluster-enabled yes
# 集群的配置文件名称,不需要我们创建,由redis自己维护
cluster-config-file /tmp/6379/nodes.conf
# 节点心跳失败的超时时间
cluster-node-timeout 5000
# 持久化文件存放目录
dir /tmp/6379
# 绑定地址
bind 0.0.0.0
# 让redis后台运行
daemonize yes
# 注册的实例ip
replica-announce-ip 192.168.137.138
# 保护模式
protected-mode no
# 数据库数量
databases 1
# 日志
logfile /tmp/6379/run.log
五、将这个文件拷贝到每个目录下
# 进入/tmp目录
cd /tmp
# 执行拷贝
echo 7001 7002 7003 8001 8002 8003 | xargs -t -n 1 cp redis.conf
六、修改每个目录下的redis.conf,将其中的6379修改为与所在目录一致:
# 进入/tmp目录
cd /tmp
# 修改配置文件
printf '%s\n' 7001 7002 7003 8001 8002 8003 | xargs -I{} -t sed -i 's/6379/{}/g' {}/redis.conf
七、启动服务
# 进入/tmp目录
cd /tmp
# 一键启动所有服务
printf '%s\n' 7001 7002 7003 8001 8002 8003 | xargs -I{} -t redis-server {}/redis.conf
ps -ef | grep redis #查看状态
八、关闭进程的两种方式
ps -ef | grep redis | awk '{print $2}' | xargs kill
# 或者
printf '%s\n' 7001 7002 7003 8001 8002 8003 | xargs -I{} -t redis-cli -p {} shutdown
九、创建集群
redis-cli --cluster create --cluster-replicas 1 192.168.137.138:7001 192.168.137.138:7002 192.168.137.138:7003 192.168.137.138:8001 192.168.137.138:8002 192.168.137.138:8003
十、查看集群状态并且测试连接
redis-cli -p 7001 cluster nodes #查看集群状态
redis-cli -c -p 7001 #测试连接