【转】redis单实例迁移到集群
2023-09-11 14:21:08 时间
转自:https://www.cnblogs.com/blazeZzz/p/11007977.html
环境说明
单机redis
192.168.41.101:6379
redis集群
192.168.41.101:7000 master 192.168.41.101:7001 master 192.168.41.101:7002 192.168.41.102:7000 master 192.168.41.102:7001 192.168.41.102:7002
迁移步骤
查看集群状态及节点槽分布
[root@blaze bin]# ./redis-cli -c -p 7000 127.0.0.1:7000> cluster nodes ab6d9f956de325cb4cf001abc31df365a5db5234 192.168.41.102:7001 slave 923c9ea13ec8fc19bed309dfbfad094320e1ca41 0 1560304528263 7 connected 48629733acbb8a580a39403dfac92845d63c97b3 192.168.41.101:7001 master - 0 1560304529768 2 connected 5461-10921 2cec8ac00f760c45d86f7903cefad85ec36704e7 192.168.41.102:7002 slave 923c9ea13ec8fc19bed309dfbfad094320e1ca41 0 1560304531271 7 connected 923c9ea13ec8fc19bed309dfbfad094320e1ca41 192.168.41.101:7000 myself,master - 0 0 7 connected 0-5460 e65b319e83997ed6f5323a26aaccba3f35522cbd 192.168.41.101:7002 slave 923c9ea13ec8fc19bed309dfbfad094320e1ca41 0 1560304532274 7 connected 5c0888d5bcceda2904311cbd5405596217c48105 192.168.41.102:7000 master - 0 1560304530268 4 connected 10922-16383
[root@blaze src]# ./redis-trib.rb check 192.168.41.101:7000 >>> Performing Cluster Check (using node 192.168.41.101:7000) M: 923c9ea13ec8fc19bed309dfbfad094320e1ca41 192.168.41.101:7000 slots:0-5460 (5461 slots) master 3 additional replica(s) S: ab6d9f956de325cb4cf001abc31df365a5db5234 192.168.41.102:7001 slots: (0 slots) slave replicates 923c9ea13ec8fc19bed309dfbfad094320e1ca41 M: 48629733acbb8a580a39403dfac92845d63c97b3 192.168.41.101:7001 slots:5461-10921 (5461 slots) master 0 additional replica(s) S: 2cec8ac00f760c45d86f7903cefad85ec36704e7 192.168.41.102:7002 slots: (0 slots) slave replicates 923c9ea13ec8fc19bed309dfbfad094320e1ca41 S: e65b319e83997ed6f5323a26aaccba3f35522cbd 192.168.41.101:7002 slots: (0 slots) slave replicates 923c9ea13ec8fc19bed309dfbfad094320e1ca41 M: 5c0888d5bcceda2904311cbd5405596217c48105 192.168.41.102:7000 slots:10922-16383 (5462 slots) master 0 additional replica(s) [OK] All nodes agree about slots configuration. >>> Check for open slots... >>> Check slots coverage... [OK] All 16384 slots covered.
把101:7001和102:7000两个master的slots转移到101:7000上
./redis-trib.rb reshard --from 5c0888d5bcceda2904311cbd5405596217c48105 --to 923c9ea13ec8fc19bed309dfbfad094320e1ca41 --slots 5462 --yes 192.168.41.101:7000 ./redis-trib.rb reshard --from 48629733acbb8a580a39403dfac92845d63c97b3 --to 923c9ea13ec8fc19bed309dfbfad094320e1ca41 --slots 5461 --yes 192.168.41.101:7000
查看转以后槽点分配
>>> Performing Cluster Check (using node 192.168.41.101:7000) M: 923c9ea13ec8fc19bed309dfbfad094320e1ca41 192.168.41.101:7000 slots:0-16383 (16384 slots) master 3 additional replica(s) S: ab6d9f956de325cb4cf001abc31df365a5db5234 192.168.41.102:7001 slots: (0 slots) slave replicates 923c9ea13ec8fc19bed309dfbfad094320e1ca41 M: 48629733acbb8a580a39403dfac92845d63c97b3 192.168.41.101:7001 slots: (0 slots) master 0 additional replica(s) S: 2cec8ac00f760c45d86f7903cefad85ec36704e7 192.168.41.102:7002 slots: (0 slots) slave replicates 923c9ea13ec8fc19bed309dfbfad094320e1ca41 S: e65b319e83997ed6f5323a26aaccba3f35522cbd 192.168.41.101:7002 slots: (0 slots) slave replicates 923c9ea13ec8fc19bed309dfbfad094320e1ca41 M: 5c0888d5bcceda2904311cbd5405596217c48105 192.168.41.102:7000 slots: (0 slots) master 0 additional replica(s) [OK] All nodes agree about slots configuration. >>> Check for open slots... >>> Check slots coverage... [OK] All 16384 slots covered.
把192.168.41.101:6379的appendonly.aof 文件复制到101:7000的aof文件目录下
cp 6379目录/appendonly.aof 7000目录
重启101:7000节点加载aof文件
[root@blaze bin]# ./redis-cli -c -p 7000 shutdown [root@blaze bin]# ./redis-server ../redis.conf
查看数据是否正确
dbsize
将101:7000的槽 均匀分配给其他两个master节点
./redis-trib.rb reshard --from 923c9ea13ec8fc19bed309dfbfad094320e1ca41 --to 5c0888d5bcceda2904311cbd5405596217c48105 --slots 5462 --yes 192.168.41.101:7000 ./redis-trib.rb reshard --from 923c9ea13ec8fc19bed309dfbfad094320e1ca41 --to 48629733acbb8a580a39403dfac92845d63c97b3 --slots 5461 --yes 192.168.41.101:7000
再次查看集群状态和槽分配。
相关文章
- redis实战笔记(10)-第10章 扩展Redis
- redis实战笔记(5)-第5章 使用 Redis构建支持程序
- redis实战笔记(3)-第3章 Redis命令
- [Redis]windows下redis的安装和启动
- 如何在redis中获取占用空间比较大的key?
- centos6安装redis
- Redis缓存异常及处理方案总结
- 一个小改进,解决Redis数据在线加载大痛点
- Try Redis : Redis 入门教程
- Redis——Lettuce连接redis集群
- Linux、数据库、Redis、MongoDB 统一管理平台,有点牛逼了!
- redis使用CacheCloud搭建(Redis云平台)搭建集群监控等等
- redis常用命令大全
- 【Redis】redis安装与客户端redis-cli的使用(批量操作)
- springmvc整合redis架构搭建实例
- centos7安装redis
- 《Redis入门指南(第2版)》一3.3 散列类型
- Redis(二)CentOS7安装Redis4.0.10与集群搭建
- redis分布式锁
- Redis学习手册(String数据类型)
- Windows Redis默认配置文件,Redis配置不生效解决方案
- windows下使用redis,Redis入门使用,Redis基础命令
- 【Redis数据结构 序】使用redis-py操作Redis数据库
- Redis 存在 userInfo用户信息技巧
- java对redis的基本操作
- Redis基础:特点(内存运行、原子性、持久化)、5种基本数据类型与3种特殊数据类型、redis命令、发布订阅机制、事务(单条命令原子性事务不是原子性)、数据备份与恢复、安全
- SpringBoot 使用jedis整合redis实现缓存处理
- 【Redis】数据结构及应用
- 单机redis 主从实例