我有一个 node.js 应用程序,使用 RedisToGo 并在 Heroku 中运行。我想将 Redis To Go 数据库复制到 localhost 进行测试。
在开发 Ruby on Rails 应用程序时,我可以使用heroku db:pull
命令。是否有任何类似的命令可用于 node.js 和 Redis?
谢谢。
redistogo支持知识库中提供了一个指南,但它被删除了,我使用返回机器获取它的内容并提出了一个要点: https ://gist.github.com/mmcdaris/29cfe920c846ae6dd5c6eb354c9abdd2 相同的结果不同的方法。
您可以将本地 Redis 实例从属到 RedisToGo 实例 - http://redistogo.com/documentation/exporting
这些是我为 Heroku Redis 实例创建本地备份所采取的步骤,但这对于 RedisToGo 和 RedisCloud 等其他提供商应该是有效的。
在您要进行备份的机器上,跳转到 redis CLI:
redis-cli
如果您的主 Redis 数据库(您要复制的数据库)有密码:
config set masterauth <password>
运行以下命令开始复制:
SLAVEOF <host> <port>
要检查复制是否正在进行,请运行:
INFO replication
您应该会看到如下内容:
# Replication
role:slave
master_host:some-host.compute-1.amazonaws.com
master_port:6519
master_link_status:up
master_last_io_seconds_ago:3
master_sync_in_progress:0
slave_repl_offset:35492914
slave_priority:100
slave_read_only:1
connected_slaves:0
master_repl_offset:0
repl_backlog_active:0
repl_backlog_size:1048576
repl_backlog_first_byte_offset:0
repl_backlog_histlen:0
注意master_link_status
应该是up
.
同步完成后,INFO replication
应显示:
master_sync_in_progress:0
要检查数据集是否已同步,您可以比较数据库的大小:
DBSIZE
给定从属数据库和主数据库匹配中的键数,然后将数据库保存到磁盘:
BGSAVE
CONFIG GET dir
你应该找到dump.rdb
config 命令列出的。
最后,您可以使用以下命令停止复制:
SLAVEOF NO ONE
参考:Redis 复制指南