阿里云redis服务相互迁移使用中转redis服务器的解决办法

根据官方文档html

https://help.aliyun.com/document_detail/26357.htmlredis

官方文档的意思是,只能将ECS上的redis数据迁移至redis实例,数据库

可是因为要从一台redis实例迁移至另外一台redis实例,则须要使用中转redis服务的办法才能迁移。服务器

下面开始介绍方法。app

若是你的redis是2.8以上的则能够直接略过升级步骤,直接移步到迁移步骤。阿里云

使用命令后发现--pipe参数没法识别,spa

查看redis-cli版本居然是2.4.net

官网此时已是3.2.4,遂临时安装,仅用于迁移两台阿里云redis的数据。unix

以CentOS 6.5为例server

先安装tcl8.5,若是没有安装GCC编译器,须要先安装,网上自行找方法,否则编译会失败。

wget http://downloads.sourceforge.net/tcl/tcl8.5.10-src.tar.gz
tar -zxvf tcl8.5.10-src.tar.gz
cd tcl8.5.10/unix
./configure
make
make install

#安装redis3.2.4
wget http://download.redis.io/releases/redis-3.2.4.tar.gz
tar -zxvf redis-3.2.4.tar.gz
cd redis-3.2.4
make
make test //查看一下是否有错误
make install

迁移步骤开始

进入阿里云redis控制台,备份一下最新的数据库文件,下载回来,上传至同一内网的ESC中。

好比上传至~/db.rdb文件。

#使用阿里云下载的rdb文件覆盖当前临时redis的数据库文件

注意路径/root/redis-3.2.4/src为默认的安装路径,只作临时中转服务器用。

cp ~/db.rdb /root/redis-3.2.4/src/dump.rdb
#启动临时redis服务

若是当前服务器运行有redis,必须将其中止运行,否则端口会冲突。

./redis-server /root/redis-3.2.4/redis.conf

#新建一个会话,开启AOF持久化,并查看数据是否正常。
cd /root/redis-3.2.4/src/
#进入redis控制台
./redis-cli
#查看记录数
dbsize
#开启AOF持久化,用于生成AOF文件并导入新redis实例
config set appendonly yes
#退出
exit

#导入到新redis服务器中。
./redis-cli -h redis连接地址 -p 6379 -a 实例ID:redis密码 --pipe < appendonly.aof

#直到看到提示,说明导入完毕,查看是否错误。
All data transferred. Waiting for the last reply...
Last reply received from server.
errors: 0, replies: 11246304


#登入新服务器中查看是否导入成功
./redis-cli -h redis连接地址 -p 6379 -a redis密码
#查看记录数
dbsize
#退出
exit

导入完毕后,须要等待数分钟,新的redis实例控制台才会刷新配额。可是控制台操做查看是实时的。

相关文章
相关标签/搜索