我们知道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
复制代码 脚本具体解析:
- 使用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 - 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内容请搜索晓枫资讯以前的文章或继续浏览下面的相关文章希望大家以后多多支持晓枫资讯!
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |