烂泥:阿里云RDS本地恢复数据

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

clip_p_w_picpath001

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

如何把RDS在本地进行恢复呢?这个阿里云官网给出了相关的操做教程,链接以下:《RDS备份文件恢复到自建数据库》。linux

看了官网的教程,感受非常麻烦,并且也有几个比较特殊的地方没有点出来,下面是我对RDS本地恢复的步骤。sql

1、安装mysql数据库数据库

在进行RDS本地恢复数据以前,咱们须要先在本地服务器上安装mysql的5.6版本,由于RDS是5.6版本,因此咱们本地的mysql数据库要与RDS版本对应。vim

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

clip_p_w_picpath002

mysql数据库安装完毕后,咱们如今来下载RDS备份。服务器

2、下载RDS备份socket

RDS自己是有备份,并且是能够在RDS的管理后台自定义备份策略,以下:ide

clip_p_w_picpath003

咱们能够在RDS备份列表中下载已经备份好的RDS文件,以下:

clip_p_w_picpath004

经过上图,咱们能够很明显的看到RDS的备份是全量备份的,并且是物理备份的。

3、解压RDS备份文件

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

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

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

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

clip_p_w_picpath005

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

sh rds_backup_extract.sh -f /root/hins1035007_xtra_20160220031920.tar.gz -C /data

clip_p_w_picpath006

clip_p_w_picpath007

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

clip_p_w_picpath008

经过上图,能够很明显的看出,RDS是经过percona-Xtrabackup进行全量备份的。

4、修改/data目录的全部者

RDS解压完毕后,咱们须要修改/data目录的全部者。以下:

chown mysql:mysql -R /data/

clip_p_w_picpath009

5、修改my.cnf配置文件

如今咱们在/data目录下建立mysql的配置文件my.cnf,以下:

vim /data/my.cnf

[mysqld]

datadir = /data/

port = 3306

server_id = 3

socket = /data/mysqld.sock

max_allowed_packet=32M

log-error = /data/error.log

default-storage-engine=INNODB

clip_p_w_picpath010

6、启动mysql并操做

my.cnf文件建立完毕后,咱们如今来启动mysql。

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

启动命令以下:

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

clip_p_w_picpath011

注意:在此mysql启动命令,是根据mysql多实例进行的,能够查看《烂泥:mysql5.5多实例部署》。

经过上图,咱们能够很明显的看出mysql已经正常启动。如今咱们再来测试,是否能够正常链接mysql。以下:

mysql -h127.0.0.1 –uroot -p

clip_p_w_picpath012

经过上图,咱们能够很明显的看出mysql是能够正常链接的。

如今咱们再来建立root用户密码,并赋予其链接权限。以下:

use mysql;

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

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

flush privileges;

clip_p_w_picpath013

对mysql操做完毕后,咱们如今来测试mysql客户端。

7、客户端链接mysql

mysql正常启动后,咱们如今经过客户端链接数据库。以下:

clip_p_w_picpath014

clip_p_w_picpath015

经过上图,咱们能够很明显的看到RDS数据库已经在本地正常恢复了。

注意:在此有两点和官方教程不同的地方须要说明:

一、没有安装percona-Xtrabackup数据恢复软件进行数据恢复

二、数据库root用户是没有密码的

相关文章
相关标签/搜索