通过migrate命令实现两个redis实例之间的数据迁移
最佳答案 问答题库528位专家为你答疑解惑
本文适用于将源服务器的redis实例的key的数据迁移到其他服务器的redis实例
一、migrate简介:
migrate用于在Redis实例间进行数据迁移,实际上migrate命令是将dump、restore、del三个命令进行组合,从而简化了操作流程。migrate命令具有原子性,从Redis 3.0.6版本后已经支持迁移多个键的功能。migrate命令的数据传输直接在源Redis和目标Redis上完成,目标Redis完成restore后会发送OK给源Redis。
二、migrate命令参数:
MIGRATE host port key| destination-db timeout [COPY] [REPLACE] [AUTH password] [AUTH2 username password] [KEYS key]
重要参数解释:
host:目标Redis的IP地址
port:目标Redis的端口
key|“”:Redis 3.0.6 后如果需要迁移多个键,此处为空字符串""
destination-db:目标Redis的数据库索引
timeout:迁移的超时时间(单位为毫秒)
copy:如果添加此选项后,迁移后不删除源键。
replace:如果添加此选项migrate不管目标Redis是否存在该键都会正常迁移进行数据覆盖,如果不提供此参数且目标redis存在该键,则抛出异常”(error) ERR Target instance replied with error: BUSYKEY Target key name already exists.“
keys:如果要迁移多个键 keys key1 key2 key3 key4
示例:
将name1 复制到目标redis的0库,超时时间为1s,不删除源redis的key,覆盖目标redis中相同的key
MIGRATE 127.0.0.1 6379 name1 0 1000 copy replace
如果移动多个key:
MIGRATE 127.0.0.1 6379 "" 2 5000 copy replace keys key1 key2 key3 key4
三、实践测试:
1、我在本地模拟了两个redis实例。ip都为127.0.0.1,端口一个是默认的6379,一个是63791
并且分别set了不同的key
127.0.0.1:63791> keys *
1) "age"
2) "like"
3) "colour"
127.0.0.1:6379> keys *
1) "student"
2、在源redis实例63791上执行迁移命令
将age 复制到目标redis的0库,超时时间为1s,不删除源redis的key,覆盖目标redis中相同的key
127.0.0.1:63791> keys *
1) "age"
2) "like"
3) "colour"
127.0.0.1:63791>
127.0.0.1:63791>
127.0.0.1:63791>
127.0.0.1:63791>
127.0.0.1:63791> MIGRATE 127.0.0.1 6379 age 0 1000 copy replace
OK
查看6379的redis实例,可以看到age迁移成功
127.0.0.1:6379> keys *
1) "age"
2) "student"
127.0.0.1:6379> get age
"22"
再试一下replace这个参数的作用,增加这个参数代表覆盖目标key,验证一下,现在6379的实例的age是22
我们在源实例里将age改一下,然后再迁移
127.0.0.1:63791> set age 99
OK
127.0.0.1:63791> get age
"99"
127.0.0.1:63791> MIGRATE 127.0.0.1 6379 age 0 1000 copy replace
OK
查看目标实例
可以看到age已经被覆盖了
127.0.0.1:6379> keys *
1) "age"
2) "student"
127.0.0.1:6379>
127.0.0.1:6379> get age
"99"
如果不想覆盖目标实例的key,可以把replace参数去掉,在源实例执行一下命令
可以看到抛出了异常,key已经存在
127.0.0.1:63791> MIGRATE 127.0.0.1 6379 age 0 1000 copy
(error) ERR Target instance replied with error: BUSYKEY Target key name already exists.
迁移多个key的命令:
127.0.0.1:63791> MIGRATE 127.0.0.1 6379 "" 0 1000 copy replace keys age like colour
OK
查看目标实例
可以看到数据都被迁移了过来
127.0.0.1:6379> keys *
1) "like"
2) "age"
3) "student"
4) "colour"
剩下的其他参数大家可以自己验证一下~
99%的人还看了
相似问题
- YOLO目标检测——卫星遥感多类别检测数据集下载分享【含对应voc、coco和yolo三种格式标签】
- 036、目标检测-锚框
- python自动化标注工具+自定义目标P图替换+深度学习大模型(代码+教程+告别手动标注)
- 【目标测距】雷达投影测距
- OpenCV入门9——目标识别(车辆统计)
- [架构之路-247]:目标系统 - 设计方法 - 软件工程 - 结构化方法的基本思想、本质、特点以及在软件开发、在生活中的应用
- 目标分割技术-语义分割总览
- C++二分算法:找到最接近目标值的函数值
- 第五章 目标检测中K-means聚类生成Anchor box(工具)
- 深度学习交通车辆流量分析 - 目标检测与跟踪 - python opencv 计算机竞赛
猜你感兴趣
版权申明
本文"通过migrate命令实现两个redis实例之间的数据迁移":http://eshow365.cn/6-34706-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!