网站建设028,网站服务器做缓存,长沙个人网站建设,还有河北城乡和住房建设厅网站吗操作系统#xff1a;centos7
docker-ce版本#xff1a;24.0.7 1.准备redis镜像
我这里使用redis 6.0.8 镜像进行操作#xff0c;如果你也需要镜像#xff0c;在网络正常情况下直接使用
docker pull redis:6.0.8
即可进行下载#xff0c;如果你没配置国内加速器#x…操作系统centos7
docker-ce版本24.0.7 1.准备redis镜像
我这里使用redis 6.0.8 镜像进行操作如果你也需要镜像在网络正常情况下直接使用
docker pull redis:6.0.8
即可进行下载如果你没配置国内加速器他默认是找国外官网下载的可能会导致下载各种失败可以多试几次 2.生成6个容器
docker run -d --name redis-node-1 --net host --privilegedtrue -v /redis/redis-node-1:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6381
docker run -d --name redis-node-2 --net host --privilegedtrue -v /redis/redis-node-2:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6382
docker run -d --name redis-node-3 --net host --privilegedtrue -v /redis/redis-node-3:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6383
docker run -d --name redis-node-4 --net host --privilegedtrue -v /redis/redis-node-4:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6384
docker run -d --name redis-node-5 --net host --privilegedtrue -v /redis/redis-node-5:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6385
docker run -d --name redis-node-6 --net host --privilegedtrue -v /redis/redis-node-6:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6386 run -d 后台运行 --name 生成镜像的名称为* --net host 网络连接的方式 --privilegedtrue 给予容器卷权限 -v /redis/redis-node-*:/data 容器卷 --cluster-enabled yes 开启集群模式 --appendonly yes 开启持久化 --port 使用的端口 3.生成集群
docker exec -it redis-node-1 /bin/bash
随便进入一个容器
redis-cli --cluster create 192.168.6.7:6381 192.168.6.7:6382 192.168.6.7:6383 192.168.6.7:6384 192.168.6.7:6385 192.168.6.7:6386 --cluster-replicas 1 这里的ip 都是 服务器ip:端口号 把这些服务器ip全写上他自动就会分配主从 并且可以看到对应的服务器主从信息 1 主 5 从 2 主 6 从 3 主 4 从 4.进入集群
随便一个容器内 都可以使用
redis-cli -p 6381 -c
-p是选择端口号
-c 优化路由 5.查看集群信息
在redis里面可以用
CLUSTER info CLUSTER NODES 在这里通过看从服务器后面的编码可以判断主服务器的从是谁 谁是主服务器的从
在redis外
redis-cli --cluster check 192.168.6.7:6381 也是可以非常详细的看到 6.集群容错迁移
1 主 5 从 2 主 6 从 3 主 4 从
每个人的情况可能都会有所不同这是正常的在查看集群信息里从服务器后面有串数值对应的就是主服务器的数值
要求是主服务器挂了的时候从服务器必须要顶替上去
现在把node1关掉 看看5是否可以顶上 这是没关前的 关了之后可以看到原来5是从现在变成主了 当我们在开启node1 后 node1 会先变成从的并不会在启动的一瞬间抢夺主 从而在间隙间造成数据丢失相同你把node4关闭再重启他也会再给node1让位的 7.主从扩容 假如现在我们的3主3从顶不住了我们又想加两个6387 和 6388 并且精准的控制6387为主 6388为从 这个样就达到了一个集群扩容的效果 但是3个主从就已经把hash槽都占满了呀所以我们还要进行槽位分配 再新建2个容器 docker run -d --name redis-node-8 --net host --privilegedtrue -v /redis/redis-node-8:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6388 docker run -d --name redis-node-7 --net host --privilegedtrue -v /redis/redis-node-7:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6387 现在创建好两个容器后再去分配槽位
现在进到node1里面
docker exec -it redis-node-7 /bin/bash
先让他以空槽的形式进入到群集里
redis-cli --cluster add-node 192.168.6.7:6387 192.168.6.7:6381
这个你可以理解为6387就跟随6381的帮派了 可以看到现在新进来的6387还没槽位
现在开始分配槽位
redis-cli rehash 192.168.6.7:6381 4096是平均分配多少个槽位 all 等到分配完成即可 可以看到成功分配了前三家分给了第四个主服务器了一些槽位
现在新主服务器就成功添加了 再给6387添加一个从的6388 让6388成为6387的从服务器 redis-cli --cluster add-node 192.168.6.7:6388 192.168.6.7:6387 --cluster-slave --cluster-master-id eed172eddb305a5a6ee6c346020dd843b068b429 这的是6388就成为6387的从服务器了后面的hash值为6387主服务器的值 成功挂到6387下变成他的从服务器 8.主从缩容
现在反向操作 有扩就有缩只需要删掉6388 和 6387 先删从 清出来的槽号再还回去 再删主 这个是当前的4主4从
现在先删从的让后重新分配槽号 再删主的
redis-cli --cluster del-node 192.168.6.7:6388 2d7e1b164db74ab85a428e11b4335ed0e43d2f89 后面这里值为6388的值 可以看到从服务器就被删掉了
redis-cli --cluster reshard 192.168.6.7:6381
只是通过这个6381去操作整个集群实际上你可以任选一台都行 现在6387 槽位就被分配到6375了我这里只是为了方便实际上你可以一点一点的分这个槽位
分配完之后就可以去删除这个节点了
redis-cli --cluster del-node 192.168.6.7:6387 eed172eddb305a5a6ee6c346020dd843b068b429
这样就可以正常删除了 这样就变回3主3从了
这样就成功的配置全过程了