公司现在用的阿里云数据库,阿里云上虽然对RDS数据库有备份,也只能免费保存一个月,所以大部分情况需要把备份下载到本地,但是如何在本地恢复可真是话费了一番功夫。先分享如下:


公司目前使用的数据库是阿里云的RDS,目前RDS的版本为mysql5.6。如下:

阿里云RDS数据备份本地恢复_数据库

 

现在要求把RDS的数据,在公司内部本地进行恢复。

操作系统:Centos7

数据库:mysql5.6


一、安装mysql数据库

在进行RDS本地恢复数据之前,我们需要先在本地服务器上安装mysql的5.6版本,因为RDS是5.6版本,所以我们本地的mysql数据库要与RDS版本对应。

rpm -ivh http://repo.mysql.com/mysql-community-release-el6-5.noarch.rpm && yum -y install mysql-server mysql

 


阿里云RDS数据备份本地恢复_数据库_02


 

mysql数据库安装完毕后,我们现在来下载RDS备份。


二、下载RDS备份

RDS本身是有备份,而且是可以在RDS的管理后台自定义备份策略,如下:

阿里云RDS数据备份本地恢复_数据库_03 

我们可以在RDS备份列表中下载已经备份好的RDS文件,如下:

阿里云RDS数据备份本地恢复_服务器_04 

通过上图,我们可以很明显的看到RDS的备份是全量备份的,而且是物理备份的。

三、解压RDS备份文件

RDS备份文件下载完毕后,我们需要对其进行解压。按照阿里云官方文档,我们需要下载阿里云专门的脚本进行解压,而且必须是在linux OS 64bit上使用。

必须说明:RDS的备份文件只能在linux OS上进行的。在windows OS上使用第三方软件解压的话,你会发现看不到任何的文件。

下载RDS解压脚本,使用如下命令:

wget http://oss.aliyuncs.com/aliyunecs/rds_backup_extract.sh

阿里云RDS数据备份本地恢复_服务器_05 

增加权限:chmod +x hins1540971_xtra_20160918230904.tar.gz

使用RDS解压脚本,解压RDS备份文件,如下:

sh rds_backup_extract.sh -f /home/hins1035007_xtra_20160220031920.tar.gz -C /home/mysql/data

阿里云RDS数据备份本地恢复_数据库_06 

阿里云RDS数据备份本地恢复_数据库_07 

解压完毕后,我们切换到/data目录下查看RDS备份解压的文件,如下:

阿里云RDS数据备份本地恢复_服务器_08 

通过上图,可以很明显的看出,RDS是通过percona-Xtrabackup进行全量备份的。



四、修改/data目录的所有者

RDS解压完毕后,我们需要修改/data目录的所有者。如下:

chown mysql:mysql -R /data/

阿里云RDS数据备份本地恢复_服务器_09 

五、修改my.cnf配置文件

现在我们在/data目录下创建mysql的配置文件my.cnf,如下:

vim /data/my.cnf

[mysqld]

datadir = /home/mysql/data/

port = 3306

server_id = 3

socket = /home/mysql/data/mysqld.sock

max_allowed_packet=32M

log-error = /home/mysql/data/error.log

default-storage-engine=INNODB

阿里云RDS数据备份本地恢复_数据库_10 

六、启动mysql并操作

my.cnf文件创建完毕后,我们现在来启动mysql。

注意:RDS备份数据库中的root用户是没有密码的,而且此时RDS备份数据库中只有root这一个用户。

启动命令如下:

/usr/bin/mysqld_safe --defaults-file=/home/mysql/data/my.cnf &

阿里云RDS数据备份本地恢复_RDS_11 


通过上图,我们可以很明显的看出mysql已经正常启动。现在我们再来测试,是否可以正常连接mysql。如下:

mysql -h127.0.0.1 –uroot -p

阿里云RDS数据备份本地恢复_数据库_12 

通过上图,我们可以很明显的看出mysql是可以正常连接的。

现在我们再来创建root用户密码,并赋予其连接权限。如下:

use mysql;

update user set password=password('*******') where user='root';

update user set host='%' where user='root' && host='127.0.0.1';

flush privileges;

阿里云RDS数据备份本地恢复_服务器_13 

此时查看数据库信息,RDS数据库已添加成功。

阿里云RDS数据备份本地恢复_服务器_14



至此,阿里云RDS数据库备份本地恢复完成,如有不够详细之处敬请见谅。