我目前有一个live redis服务器运行在一个云实例,我想迁移这个redis服务器到一个新的云实例,并使用该实例作为我的新的redis服务器。如果它是MySQL,我将从旧服务器导出DB并将其导入到新服务器。我该如何用redis做到这一点?
附注:我不指望设置复制。我想完全迁移redis服务器到一个新的实例。
我目前有一个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已弃用-请参阅手册
其他回答
也可以使用SLAVEOF命令迁移数据:
SLAVEOF old_instance_name old_instance_port
检查您是否收到带有keys *的钥匙。你也可以用任何其他方法测试这个新实例,当你完成时,只需打开replication of:
SLAVEOF NO ONE
由于Redis 5.0推荐使用REPLICAOF,因为SLAVEOF已弃用-请参阅手册
如果您在服务器之间有连接,最好将新实例作为从节点设置复制(与SQL不同,这很简单),然后您可以用一个命令将新节点切换到主节点,并且无需停机时间。
我刚刚发布了一个命令行接口实用程序到npm和github,它允许你从一个Redis数据库复制匹配给定模式(甚至*)的键到另一个。
你可以在这里找到实用工具:
https://www.npmjs.com/package/redis-utils-cli
去查查垃圾场在哪。导入redis数据时必须放置RDB,
开始客户端
$ redis-cli
and
then
redis 127.0.0.1:6379> CONFIG GET *
1) "dir"
2) "/Users/Admin"
这里/Users/Admin是转储的位置。从服务器读取的RDB,因此这是必须被替换的文件。
我还想做同样的事情:将一个db从一个独立的redis实例迁移到另一个redis实例(redis哨兵)。
因为数据不是关键(会话数据),我将尝试https://github.com/yaauie/redis-copy。