我目前有一个live redis服务器运行在一个云实例,我想迁移这个redis服务器到一个新的云实例,并使用该实例作为我的新的redis服务器。如果它是MySQL,我将从旧服务器导出DB并将其导入到新服务器。我该如何用redis做到这一点?

附注:我不指望设置复制。我想完全迁移redis服务器到一个新的实例。


当前回答

也可以使用SLAVEOF命令迁移数据:

SLAVEOF old_instance_name old_instance_port

检查您是否收到带有keys *的钥匙。你也可以用任何其他方法测试这个新实例,当你完成时,只需打开replication of:

SLAVEOF NO ONE

由于Redis 5.0推荐使用REPLICAOF,因为SLAVEOF已弃用-请参阅手册

其他回答

现在,您还可以使用MIGRATE,从2.6开始提供。

我必须使用这个,因为我只想移动一个数据库中的数据,而不是所有数据库中的数据。这两个Redis实例位于两台不同的机器上。

如果你不能从Redis-1直接连接到Redis-2,使用ssh端口绑定:

 ssh user@redis-2.foo.com -L 1234:127.0.0.1:6379

一个小脚本,使用keys循环所有键并迁移每个键。这是Perl,但希望您能理解:

 foreach ( $redis_from->keys('*') ) {

    $redis_from->migrate(
        $destination{host},    # localhost in my example
        $destination{port},    # 1234
        $_,                    # The key
        $destination{db},
        $destination{timeout} 
    );
 }

更多信息请参见http://redis.io/commands/migrate。

您也可以使用RDD

它可以转储和恢复一个运行的redis服务器,并允许过滤/匹配/重命名转储键

也可以使用SLAVEOF命令迁移数据:

SLAVEOF old_instance_name old_instance_port

检查您是否收到带有keys *的钥匙。你也可以用任何其他方法测试这个新实例,当你完成时,只需打开replication of:

SLAVEOF NO ONE

由于Redis 5.0推荐使用REPLICAOF,因为SLAVEOF已弃用-请参阅手册

我还想做同样的事情:将一个db从一个独立的redis实例迁移到另一个redis实例(redis哨兵)。

因为数据不是关键(会话数据),我将尝试https://github.com/yaauie/redis-copy。

我刚刚发布了一个命令行接口实用程序到npm和github,它允许你从一个Redis数据库复制匹配给定模式(甚至*)的键到另一个。

你可以在这里找到实用工具:

https://www.npmjs.com/package/redis-utils-cli