4

我有一个 node.js 应用程序,使用 RedisToGo 并在 Heroku 中运行。我想将 Redis To Go 数据库复制到 localhost 进行测试。

在开发 Ruby on Rails 应用程序时,我可以使用heroku db:pull命令。是否有任何类似的命令可用于 node.js 和 Redis?

谢谢。

4

3 回答 3

5

redistogo支持知识库中提供了一个指南,但它被删除了,我使用返回机器获取它的内容并提出了一个要点: https ://gist.github.com/mmcdaris/29cfe920c846ae6dd5c6eb354c9abdd2 相同的结果不同的方法。

于 2012-07-06T23:58:30.230 回答
4

您可以将本地 Redis 实例从属到 RedisToGo 实例 - http://redistogo.com/documentation/exporting

于 2012-06-20T11:26:29.700 回答
1

这些是我为 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.rdbconfig 命令列出的。

停止复制

最后,您可以使用以下命令停止复制:

SLAVEOF NO ONE

参考:Redis 复制指南

于 2017-03-08T15:16:25.233 回答