如何进行RDS针对数据库级别的备份及回滚

如何进行RDS针对数据库级别的备份及回滚,第1张

目前可采取两种方式:

第一种方式,直接对RDS实例进行库备份回滚 *** 作

第二种方式,针对备份点生成的临时实例,对临时实例进行库备份,回滚到RDS实例

第一种方式:直接对RDS实例进行库备份回滚

第一步:在云服务器(linux系统)上安装MySQL客户端工具

1)下载mysql客户端工具

执行: wget http //dev mysql com/get/archives/mysql-5.6/MySQL-client-5.6.15-1.linux_glibc2.5.x86_64.rpm

2)安装mysql客户端工具

执行:rpm -ivh MySQL-client-5.6.15-1.linux_glibc2.5.x86_64.rpm

或者您可以直接在系统内使用yum install mysql进行安装MySQL客户端。

第二步:对RDS实例执行库备份 *** 作

执行命令完成库备份:mysqldump -h xxx.mysql.aliyun.com -u xxx -P 3306 -p --opt --default-character-set=utf8 --triggers --hex-blob db_name >/tmp/db_name.sql

(点击查看全图)

输入密码后,mysqldump将进行备份 *** 作并自动完成。

检测备份生成sql文件,执行 ll xx.sql

第三步:针对RDS实例执行回滚 *** 作

根据备份文件,执行以下命令进行RDS实例回滚 *** 作

mysql -h xxxxxx.mysql.rds.aliyuncs.com -u user_name -P 3306 -p database_name

(点击查看全图)

输入密码后,将完成回滚 *** 作

第二种方式:针对备份点生成的临时实例,对临时实例进行库备份,回滚到RDS实例

第一步:在云服务器(linux系统)上安装mysql客户端工具

1)下载mysql客户端工具

执行: wget http://cdn.mysql.com/Downloads/MySQL-5.5/MySQL-client-5.5.32-2.linux2.6.x86_64.rpm

2)安装mysql客户端工具

执行:rpm -ivh MySQL-client-5.5.32-2.linux2.6.x86_64.rpm

第二步:在阿里云RDS控制台中创建临时实例

点击RDS控制台“备份恢复”页面,选择一个备份集创建临时实例,如下图

(点击查看全图)

每个RDS实例可以创建一个临时实例,临时实例有只读权限,并且继承备份点的帐号和密码以及内外网状态,创建成功后48个小时内有效

创建临时实例成功后,在临时实例列表中可以查看临时实例信息,如:临时实例连接字符串,端口号,访问临时实例的帐号名(创建备份点时RDS实例中存在的帐号),网络类型等等。

(点击查看全图)

第三步:针对子实例进行mysql按库备份 *** 作

执行以下命令对子实例进行库备份 *** 作

mysqldump -h xxx.mysql.aliyun.com -u xxx -P 3306 -p --opt --default-character-set=utf8 --triggers --hex-blob db_name >/tmp/db_name.sql

(点击查看全图)

输入密码后,完成子实例的备份 *** 作。

注:上图红色圈内应输入子实例的连接地址,用户名以及数据库名

第四步:针对RDS实例进行回滚 *** 作

执行以下命令对RDS实例进行回滚 *** 作

mysql-h xxxxxx.mysql.rds.aliyuncs.com -u xxxx -P 3306 -p database_name

(点击查看全图)

输入密码后,完成RDS实例的回滚 *** 作

注:上图红色圈内应输入RDS实例连接地址,用户名以及数据库名

恢复数据库到之前的某个时间点,必须要有日志备份。

下面是一个使用日志的示例:

create database db1

go

alter database db1 set recovery full

go

backup database db1 to disk='db1.bak' with init--首先要对数据库进行全备份,否则checkpoint会阶段inactive的日志(类似于simple recovery)

go

use db1

go

create table t(col int)

go

---一些数据库 *** 作

---一些数据库 *** 作

---一些数据库 *** 作

--假设你在15点15分以后删除了这个表

drop table t

--如果想恢复这个表,需要对数据库进行日志备份

use master

go

backup log db1 to disk='db1.trn' with norecovery

go

---然后执行以下 *** 作

use master

go

restore database db1 from disk='db1.bak' with norecovery

go

restore log db1 from disk='db1.trn' with recovery,stopat='2009-03-08 15:15:00'--这时,数据库恢复到15:15的状态。

用户在购买完RDS后,接下来就可以开始往RDS迁入数据了。在RDS刚刚对外提供服务的时候,用户只能通过将自己的数据库dump成为sql文件,然后再将sql文件source到RDS中去:数据迁移至RDS-MySQL之使用MySQLdump工具,数据迁移至RDS-SQLserver之利用SQL Server客户端工具,这两种方法是最简单的方法,但是局限性也非常的多:

.用户的数据库太大了,逻辑sql导入的方式速度太慢了,严重影响停机时间;

.在导入的过程中报错很多,或者导入一半的过程中中断了,需要重新来过;

.在迁入RDS过程中,希望我的数据库还能能正常提供服务;

大量的用户入云全部堵在迁移数据上面,用户与RDS的缘分就差么这临门一脚。工欲善必先利其器,为了更好的帮助用户入云,RDS对现有的用户入云迁移方式进行改进,帮助用户快速稳定迁移入云,分别为用户提供了mysql和sqlserver两套改良迁移工具:

.mysql迁移工具支持在线迁移,用户可以不中断业务的情况下把数据迁移到RDS中来

.sqlserver的迁移工具采用物理备份的方法,将用户的物理备份上传到FTP中后还原到RDS,提升迁移的速度

这两套工具目前都已经集成到了RDS的控制台中,可以参考:数据迁移至RDS-MySQL之使用阿里云控制台和 数据迁移至RDS-SQLserveru阿里云控制台.

很多用户在控制台上看到的只是一个黑盒子,在工单中多次咨询迁移的原理,在这里大致讲一下这两个工具的迁移实现:

Mysql在线迁移的原理:

第一步:预检查,主要是验证用户网络的通畅性,账号和环境的检查;

第二步:全量备份,该步骤会把用户的数据全量的dump出一份出来,然后还原到RDS;

第三步:增量迁移,该步骤会解析用户全量期间以及后续产生的binlog应用到RDS;

第四步:切换,当RDS的数据完全追上用户的数据库后,用户就可以开始进行切换了;

Mysql的在线迁移工具目前还有一些限制,比如:

mysql 5.0只支持全量迁移,不支持增量迁移;

不支持mysql5.6的迁移;不支持存储过程,触发器的迁移;

迁移过程中如果有ddl发生则会导致增量迁移失败;

SQLSERVER工具迁移的原理:

第一步:备份用户对本地数据库进行物理备份

第二步:备份上传至RDS提供的ftp服务器上(ftp地址支持私网和公网上传)

第三步:RDS扫描校验用户上传备份文件通过后,恢复至用户RDS

第四步:用户切换应用至RDS

由于sqlserver目前还没有开放日志接口,所以RDS目前还不能支持在线迁移;

RDS目前不支持master库的导入。

希望这篇文章对你使用RDS有帮助。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10013653.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存