【Docker】redis分片集群搭建:3主3从,容错迁移,扩缩容-创新互联
Docker是基于Go语言实现的云开源项目。Docker的主要目标是**“Build,Ship and Run Any App,Anywhere”**。也就是通过对应用组件的封装、分发、部署、运行等生命周期的管理,使用户的APP(可以是一个WEB应用或数据库应用等等)及其运行环境能够做到“一次镜像,处处运行”。
成都创新互联公司服务项目包括邛崃网站建设、邛崃网站制作、邛崃网页制作以及邛崃网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,邛崃网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到邛崃省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!一、集群搭建
修改云服务器安全组开放对应端口(注意:包括总线端口,如16381)、关闭云服务器内部防火墙并重启Docker(systemctl stop firewalld)
新建6个 redis容器实例
docker run -d --name redis-node-1 --net host --privileged=true -v /mydata/redis/cluster/redis-node-1:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6381 docker run -d --name redis-node-2 --net host --privileged=true -v /mydata/redis/cluster/redis-node-2:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6382 docker run -d --name redis-node-3 --net host --privileged=true -v /mydata/redis/cluster/redis-node-3:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6383 docker run -d --name redis-node-4 --net host --privileged=true -v /mydata/redis/cluster/redis-node-4:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6391 docker run -d --name redis-node-5 --net host --privileged=true -v /mydata/redis/cluster/redis-node-5:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6392 docker run -d --name redis-node-6 --net host --privileged=true -v /mydata/redis/cluster/redis-node-6:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6393
进入 redis-6381 容器实例,并为6台机器构建集群关系
redis-cli --cluster create 114.132.162.129:6381 114.132.162.129:6382 114.132.162.129:6383 114.132.162.129:6391 114.132.162.129:6392 114.132.162.129:6393 --cluster-replicas 1 #--cluster-replicas 1 表示为每个master创建一个slave节点
进入 redis-6381 容器实例,查看集群信息
redis-cli -p port cluster info cluster nodes
读写数据:非集群模式、集群模式
redis -p 6381 -c
查看集群信息
redis-cli --cluster check 114.132.162.129:6381
将 redis-6381 停了,容器实例 redis-6392 上位。
6381宕机了,6392上位成为了新的master。
还原集群初始状态
过程中需要等待一会儿,docker集群重新响应。
查看集群信息
新建 redis-6384(主)、redis-6394(从) 两个redis容器实例
docker run -d --name redis-node-7 --net host --privileged=true -v /mydata/redis/cluster/redis-node-7:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6384 docker run -d --name redis-node-8 --net host --privileged=true -v /mydata/redis/cluster/redis-node-8:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6394
进入容器实例 redis-6384 ,将 自己(空槽号) 作为master节点加入原集群。并检查集群信息1
redis-cli --cluster add-node 114.132.162.129:6384 114.132.162.129:6381 #6384 就是将要作为master的新增节点, 6381 就是原来集群节点里面的领路人,相当于6384拜6381的码头从而找到组织加入集群 redis-cli --cluster check 114.132.162.129:6384
重新分配槽位
redis-cli --cluster reshard 114.132.162.129:6381
槽位怎么获得?从其他3家各自匀出来一部分
检查集群信息2
redis-cli --cluster check 114.132.162.129:6381
为什么6387是3个新的区间,以前的还是连续?
重新分配的成本太高,所以前3家各自匀出来一部分,从6381/6382/6383三个旧的主节点分别匀出1364个坑位给新主节点6387
为主节点 redis-6384 分配从节点 redis-6394
redis-cli --cluster add-node 114.132.162.129:6394 114.132.162.129:6384 --cluster-slave --cluster-master-id a84049bf1569e3021eb016626b5c7d8c168d1d39 #最后为新主节点id(redis-6384的id)
检查集群信息3
redis-cli --cluster check 114.132.162.129:6384
目的:reids-6384 和 redis-6394 下线
从集群中将 redis-6394从节点 删除(先删除从节点)
redis-cli --cluster del-node 114.132.162.129:6394 2f153dac33d9b5a4add859ec44579b48d3fd05e7
将集群中 reids-6384 的槽位重新分配
redis-cli --cluster reshard 114.132.162.129:6381
检查集群信息
redis-cli --cluster check 114.132.162.129:6384
删除 redis-6384主节点
redis-cli --cluster del-node 114.132.162.129:6384 a84049bf1569e3021eb016626b5c7d8c168d1d39
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧
分享文章:【Docker】redis分片集群搭建:3主3从,容错迁移,扩缩容-创新互联
文章网址:http://azwzsj.com/article/cesjgj.html