10人参与 • 2025-04-24 • Redis
我们知道migrate 命令可以迁移redis的多个key,但是如果redis的key有非常多,那用起来就很不方便了。
所以下面分享一个脚本来实现批量key的迁移,主要使用的命令为dump和restore
脚本如下:
#!/bin/bash redis-cli -h host1 -p 63791 -n 0 keys "*" | while read key do 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 echo "migrate key $key" done
脚本具体解析:
测试:
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、使用脚本批量将63791实例的key迁移到6379实例
我的脚本如下:
#!/bin/bash redis-cli -h 127.0.0.1 -p 63791 -n 0 keys "*" | while read key do 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 echo "migrate key $key" done
执行sh migrate.sh启动脚本
jiagangdemacbook-pro jag-ide-dev/redis » sh migrate.sh ok migrate key age ok migrate key like ok migrate key colour
查看6379实例
可以看到63791实例上的数据已经被迁移了过来
127.0.0.1:6379> keys * 1) "like" 2) "age" 3) "student" 4) "colour" 127.0.0.1:6379> get colour "red"
到此这篇关于redis批量迁移key的实例的文章就介绍到这了,更多相关redis批量迁移key内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
您想发表意见!!点此发布评论
版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。
发表评论