【发布时间】:2015-08-10 19:23:20
【问题描述】:
如何转储在数据库 0 上运行的 redis 并将其恢复到不同数据库 (8) 上的本地计算机中?
我已经安全地复制了转储文件:
scp hostname@/var/lib/redis/dump.rdb .
但是如果我用这个更改我的本地redis dump.rdb,我会得到数据库0上的数据。我怎样才能将它恢复到特定的数据库?
【问题讨论】:
标签: redis
如何转储在数据库 0 上运行的 redis 并将其恢复到不同数据库 (8) 上的本地计算机中?
我已经安全地复制了转储文件:
scp hostname@/var/lib/redis/dump.rdb .
但是如果我用这个更改我的本地redis dump.rdb,我会得到数据库0上的数据。我怎样才能将它恢复到特定的数据库?
【问题讨论】:
标签: redis
首先请注意,使用编号/共享的 Redis 数据库是不可取的。您真的应该考虑使用带有单个 DB (0) 的专用 Redis 服务器(更多信息请访问:https://redislabs.com/blog/benchmark-shared-vs-dedicated-redis-instances)
Redis 没有提供一种直接的方法来做到这一点,但是有两种基本的方法可以做到这一点:
预处理:修改dump.rdb 文件以加载到您选择的数据库中。您可以为此构建一个工具,或者使用现有的工具之一。 Jan-Erik 在 http://rdb.fnordig.de/file_format.html 记录 RDB v7 格式方面做得非常出色,因此您只需更改 Database Selector 字节即可。
【讨论】:
我最终在 Ruby 中创建了一个脚本来转储和恢复我想要的密钥。 (请注意,这种方法很慢,200 个键大约需要 1 分钟)。
ssh hostname redis-cli --scan --pattern 'awesome_filter_pattern*'
dump = ssh.exec!("redis-cli dump #{key}").chomp
$redis.connection.restore(key, 0, dump)
【讨论】: