当前位置: 首页 > news >正文

通过migrate命令实现两个redis实例之间的数据迁移

本文适用于将源服务器的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"

剩下的其他参数大家可以自己验证一下~

http://www.lryc.cn/news/222062.html

相关文章:

  • Unity 判断两个UI是否相交
  • swoole process 消息通信
  • uniapp跳转方式
  • 六大排序算法:插入、选择、冒泡、快排、希尔、归并
  • 短信登录实现(黑马点评为例)
  • 【uniapp】签名组件,兼容vue2vue3
  • 初步利用Ansible实现批量服务器自动化管理
  • 网络安全和隐私保护技术
  • 保险行业采购管理痛点及解决方案(数智化采购系统)
  • 光学仿真 | 仿真推动以人类视觉感知为本的汽车显示设计
  • 判断两个对象是否不相等operator.ne()
  • 2023年云计算发展趋势:生活的智能未来
  • Spring Boot项目中通过 Jasypt 对属性文件中的账号密码进行加密
  • 2.3 矩阵消元
  • Docker 从构建开始导出一个镜像
  • 案例研究|腾讯音乐娱乐集团与JumpServer共探安全运维审计解决方案
  • 如何卸载在linux下通过rpm安装的mysql
  • docker复制镜像文件
  • 自动驾驶学习笔记(六)——Apollo安装
  • 四阶龙格库塔与元胞自动机
  • Mac安装opencvJava踩坑
  • YOLOv8-Pose推理详解及部署实现
  • django+drf+vue 简单系统搭建 (1) - django创建项目
  • 各种NoSQL数据库
  • 基于8086家具门安全控制系统设计
  • k8s:kubectl 详解
  • 壹基金防灾减灾宣传进社区 提升家庭安全能力
  • 抖音自动发评论软件下载方法与其使用方法与案例分析分享
  • Java代码实现当前时间增加3个月
  • 互联网系统安全(一)