设为首页收藏本站
网站公告 | 这是第一条公告
     

 找回密码
 立即注册
缓存时间02 现在时间02 缓存数据 我们最后一次见面是一起看《摆渡人》里面有句台词:原来此刻坐在身边的人也会走散。他紧抓了我手一下,我莫名心里一沉。过了一周跟我说了分手。但是那个手的力度我还记得。

我们最后一次见面是一起看《摆渡人》里面有句台词:原来此刻坐在身边的人也会走散。他紧抓了我手一下,我莫名心里一沉。过了一周跟我说了分手。但是那个手的力度我还记得。 -- 空心

查看: 603|回复: 0

redis批量迁移key的实例

[复制链接]

  离线 

TA的专栏

  • 打卡等级:即来则安
  • 打卡总天数:27
  • 打卡月天数:0
  • 打卡总奖励:310
  • 最近打卡:2025-09-26 14:23:21
等级头衔

等級:晓枫资讯-上等兵

在线时间
0 小时

积分成就
威望
0
贡献
328
主题
282
精华
0
金钱
1249
积分
668
注册时间
2023-2-11
最后登录
2025-9-26

发表于 2025-9-1 04:38:28 | 显示全部楼层 |阅读模式
我们知道migrate 命令可以迁移redis的多个key,但是如果redis的key有非常多,那用起来就很不方便了。
所以下面分享一个脚本来实现批量key的迁移,主要使用的命令为dumprestore
脚本如下:
  1. #!/bin/bash
  2. redis-cli -h host1 -p 63791 -n 0 keys "*" | while read key
  3. do
  4. redis-cli -h host1 -p 63791 -n 0 --raw dump $key | perl -pe 'chomp if eof' | redis-cli -h host2 -p 6379 -n 0 -x restore $key 0
  5. echo "migrate key $key"
  6. done
复制代码
脚本具体解析:

  • 使用redis-cli连接到host1服务器,n代表database,执行keys "*"命令获取所有键名。
  • 使用while read key循环读取每个键名。
  • 对于每个键名,使用redis-cli连接到host1服务器,执行dump命令将键值序列化输出。
  • 使用perl -pe 'chomp if eof’命令处理输出结果,去除换行符。
  • 使用redis-cli连接到host2服务器,执行restore命令将键值恢复到host2服务器,ttl=0代表永不过期。
  • 输出迁移的键名。
测试:
1、我在本地模拟了两个redis实例。ip都为127.0.0.1,端口一个是默认的6379,一个是63791
并且分别set了不同的key
  1. 127.0.0.1:63791> keys *
  2. 1) "age"
  3. 2) "like"
  4. 3) "colour"
复制代码
  1. 127.0.0.1:6379> keys *
  2. 1) "student"
复制代码
2、使用脚本批量将63791实例的key迁移到6379实例
1.png

我的脚本如下:
  1. #!/bin/bash
  2. redis-cli -h 127.0.0.1 -p 63791 -n 0 keys "*" | while read key
  3. do
  4. redis-cli -h 127.0.0.1 -p 63791 -n 0 --raw dump $key | perl -pe 'chomp if eof' | redis-cli -h 127.0.0.1 -p 6379 -n 0 -x restore $key 0
  5. echo "migrate key $key"
  6. done
复制代码
执行sh migrate.sh启动脚本
  1. jiagangdeMacBook-Pro jag-ide-dev/redis » sh migrate.sh
  2. OK
  3. migrate key age
  4. OK
  5. migrate key like
  6. OK
  7. migrate key colour
复制代码
查看6379实例
可以看到63791实例上的数据已经被迁移了过来
  1. 127.0.0.1:6379> keys *
  2. 1) "like"
  3. 2) "age"
  4. 3) "student"
  5. 4) "colour"
  6. 127.0.0.1:6379> get colour
  7. "red"
复制代码
到此这篇关于redis批量迁移key的实例的文章就介绍到这了,更多相关redis批量迁移key内容请搜索晓枫资讯以前的文章或继续浏览下面的相关文章希望大家以后多多支持晓枫资讯!

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
晓枫资讯-科技资讯社区-免责声明
免责声明:以上内容为本网站转自其它媒体,相关信息仅为传递更多信息之目的,不代表本网观点,亦不代表本网站赞同其观点或证实其内容的真实性。
      1、注册用户在本社区发表、转载的任何作品仅代表其个人观点,不代表本社区认同其观点。
      2、管理员及版主有权在不事先通知或不经作者准许的情况下删除其在本社区所发表的文章。
      3、本社区的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,举报反馈:点击这里给我发消息进行删除处理。
      4、本社区一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
      5、以上声明内容的最终解释权归《晓枫资讯-科技资讯社区》所有。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~
严禁发布广告,淫秽、色情、赌博、暴力、凶杀、恐怖、间谍及其他违反国家法律法规的内容。!晓枫资讯-社区
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|晓枫资讯--科技资讯社区 本站已运行

CopyRight © 2022-2025 晓枫资讯--科技资讯社区 ( BBS.yzwlo.com ) . All Rights Reserved .

晓枫资讯--科技资讯社区

本站内容由用户自主分享和转载自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。

如有侵权、违反国家法律政策行为,请联系我们,我们会第一时间及时清除和处理! 举报反馈邮箱:点击这里给我发消息

Powered by Discuz! X3.5

快速回复 返回顶部 返回列表