首页 » Linux » 阿里云的RDS的备份数据恢复到本地的数据库

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

 

需要了解以下几点,

1、阿里云使用的是RDS-mysql,阿里云每天的备份是物理备份,也就是复制数据目录下的所有内容。

2、阿里云的RDS中是没有root账号。

3、阿里云的RDS全备下载下来是*.tar.gz,解压的话是不可以用我们自己的工具,需要用它们自己的工具才能解压出来数据,不然是空的。

4、注意你的RDS版本最好要与你的本地数据库的版本一致,至少大版本也一致,如5.6,5.5或5.7

可以参考官方和网友的文档:

https://help.aliyun.com/knowledge_detail/41817.html?spm=5176.7841816.2.1.Lz7Rvi

http://www.ilanni.com/?p=10861

报错:

[root@7-node2 data]# mysql -uroot -p
Enter password: 
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/application/mysql/data/mysql.sock' (2)
解决方法:
查看目录下是不是有sock
[root@7-node2 data]# ll
total 330352
-rw-r----- 1 mysql root 157976 Aug 11 11:13 7-node2.err
-rw-rw---- 1 mysql mysql 56 Aug 11 11:14 auto.cnf
-rw-r--r-- 1 mysql mysql 319 Aug 11 11:10 backup-my.cnf
-rw-r----- 1 mysql root 446260 Aug 11 11:59 error.log
-rw-r----- 1 mysql mysql 209715200 Aug 11 12:04 ibdata1
-rw-rw---- 1 mysql mysql 50331648 Aug 11 12:05 ib_logfile0
-rw-rw---- 1 mysql mysql 50331648 Aug 11 11:14 ib_logfile1
-rw------- 1 mysql mysql 26657409 Aug 11 11:10 log000000000002.tokulog27
-rw-rw---- 1 mysql mysql 140 Aug 11 11:14 master.info
-rw-r--r-- 1 root root 220 Aug 11 11:14 my.cnf
drwxr-xr-x 2 mysql mysql 4096 Aug 11 11:10 mysql
srwxrwxrwx 1 mysql mysql 0 Aug 11 12:04 mysqld.sock
-rw-r----- 1 mysql root 473146 Aug 11 12:04 mysql_err.log
-rw-rw---- 1 mysql mysql 6 Aug 11 12:04 mysql.pid
drwxr-xr-x 2 mysql mysql 4096 Aug 11 11:10 performance_schema
-rw-rw---- 1 mysql mysql 591 Aug 11 12:04 slow.log
drwxr-xr-x 2 mysql mysql 19 Aug 11 11:10 test
-rw-r----- 1 mysql mysql 16384 Aug 11 11:10 tokudb.directory
-rw-r----- 1 mysql mysql 16384 Aug 11 11:10 tokudb.environment
-rw-r----- 1 mysql mysql 16384 Aug 11 11:10 tokudb.rollback
drwxr-xr-x 2 mysql mysql 4096 Aug 11 11:10 xingou
-rw-r--r-- 1 mysql mysql 70 Aug 11 11:10 xtrabackup_binlog_info
-rw-r----- 1 mysql mysql 93 Aug 11 11:10 xtrabackup_checkpoints
-rw-r--r-- 1 mysql mysql 797 Aug 11 11:10 xtrabackup_info
-rw-r----- 1 mysql mysql 3072 Aug 11 11:10 xtrabackup_logfile
-rw-r--r-- 1 mysql mysql 75 Aug 11 11:10 xtrabackup_slave_filename_info
-rw-r--r-- 1 mysql mysql 112 Aug 11 11:10 xtrabackup_slave_info


发现是mysqld.sock多了一个d ,所以提示找不到。所以在配置文件中加上d 就可以了
socket = /application/mysql/data/mysqld.sock

 

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

clip_image001

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

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

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

一、安装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

clip_image002

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

二、下载RDS备份

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

clip_image003

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

clip_image004

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

三、解压RDS备份文件

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

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

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

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

clip_image005

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

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

clip_image006

clip_image007

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

clip_image008

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

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

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

chown mysql:mysql -R /data/

clip_image009

五、修改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_image010

六、启动mysql并操作

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

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

启动命令如下:

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

clip_image011

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

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

mysql -h127.0.0.1 –uroot -p

clip_image012

通过上图,我们可以很明显的看出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_image013

对mysql操作完毕后,我们现在来测试mysql客户端。

注意:如果不想这么麻烦的话,我们可以直接跳过用户验证,使用如下命令:

/usr/bin/mysqld_safe –defaults-file=/data/my.cnf –skip-grant-table&

这样客户端在连接时,可以任意用户名和密码。

七、客户端连接mysql

mysql正常启动后,我们现在通过客户端连接数据库。如下:

clip_image014

clip_image015

通过上图,我们可以很明显的看到RDS数据库已经在本地正常恢复了。

注意:在此有两点和官方教程不一样的地方需要说明:

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

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

 

 

 

 

 

原文链接:阿里云的RDS的备份数据恢复到本地的数据库,转载请注明来源!

0