mysql平滑迁移到redis_两个Redis集群如何平滑数据迁移

来自:掘金(作者:冷冷gg)

原文链接:

问题

由于生产环境的各种原因,我们需要对现有服务器进行迁移,包括线上正在运行的 redis 集群环境 如何去做?

涉及到数据源变动,原有数据如何平滑迁移到新实例,从而可以实现无缝迁移?

方案汇总

基于 redis 自身的RDB/AOF 备份机制

ead066a6ca1acb2978f8ba2baa87e4cb.png

image

执行 save\bgsave 触发数据持久化 RDB文件

拷贝redis备份文件(dump.rdb)到目标机器

重启目标实例重新load RDB 文件

关于 save/bgsave 的区别

命令

save

bgsave

IO阻塞

同步

异步

复杂度

O(n)

O(n)

缺点

阻塞客户端

需要fork,消耗内存

基于redis-dump导入导出json备份

e735a6dc2193dde160a8bf73e5550383.png

image

# 导出命令

redis-dump –u 127.0.0.1:6379 > lengleng.json

# 导出指定数据库数据

redis-dump -u 127.0.0.1:6379 -d 15 > lengleng.json

# 如果redis设有密码

redis-dump –u :password@127.0.0.1:6379 > lengleng.json

# 导入命令

< lengleng.json redis-load

# 指定redis密码

< lengleng.json redis-load -u :password@127.0.0.1:6379

基于 redis-shake 实现 redis-cluster****迁移

redis-shake是阿里云Redis&MongoDB团队开源的用于redis数据同步的工具https://github.com/alibaba/RedisShake。

7a1581159a1dc6ef334626f2dc4bb528.png

image

基于 Docker创建两个集群

docker run --name redis-cluster1 -e CLUSTER_ANNOUNCE_IP=192.168.0.31 -p 8000-8005:7000-7005 -p 18000-18005:17000-17005 pig4cloud/redis-cluster:4.0

docker run --name redis-cluster2 -e CLUSTER_ANNOUNCE_IP=192.168.0.31 -p 8000-8005:7000-7005 -p 18000-18005:17000-17005 pig4cloud/redis-cluster:4.0

配置 redis-shake.conf

执行全量、增量同步

d59690a2f8cc29024711fe15666f1fe4.gif

image

restful监控指标

# 用户可以通过restful监控指标查看内部运行状况,默认的restful端口是9320:

http://127.0.0.1:9320/metric

a485fc306c33c7356d1b787a1f1080c9.png

image

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值