共计 1481 个字符,预计需要花费 4 分钟才能阅读完成。
准备工作
1、安装 mysql,版本要和 RDS 实例的版本一致;2、安装 mysql 备份恢复工具 percona-xtrabackup,下载地址为 https://www.percona.com/downl…3、rds 上创建一个普通账户,无需分配任何库的权限,用于从库同步使用;4、添加 ecs 实例 IP 至 RDS 白名单;5、下载 RDS 的全量备份至 ECS 实例,全量备份坐标见下图;
从备份数据恢复
1、添加下述参数至 mysql 配置文件的 [mysqld] 标签下;
server-id = 2156239584
log-bin=mysql-bin
relay-log=relay-bin
gtid_mode=on
enforce_gtid_consistency=on
binlog_format=row
log_slave_updates=1
2、解压下载的全量备份至临时目录,自己可以随意指定,本文指定为 /data/tmp
3、恢复数据
innobackupex –apply-log /data/tmp/
innobackupex –copy-back /data/tmp/
4、修改 mysql 配置文件为跳过授权,即添加下述配置至 [mysqld] 标签下
skip-grant-tables
如下图所示
5、修改 mysql 数据文件夹的属主为 mysql 用户,我的 mysql 数据是放在 /data/mysql,如果不特殊指定的话是在 /var/lib/mysql
chown -R mysql. /data/mysql
6、启动 mysql 服务
service mysqld start
7、清空 mysql 库下的 slave 相关表信息
use mysql;
truncate slave_gtid_info;
truncate slave_master_info;
truncate slave_relay_log_info;
truncate slave_worker_info;
8、修改 root 账户密码
update mysql.user set password=password(‘Your_password’) where user=’root’;
9、注释或删除跳过授权表的配置并重新启动 mysql,如下图所示
service mysqld restart
8、配置主从再次登录 mysql 数据库时请指定 -h 127.0.0.1
reset slave;
change master to master_host=’rm-xxxxxxxx.mysql.rds.aliyuncs.com’,master_port=3306,master_user=’xxxxxxxx’,master_password=’xxxxxxxx’,master_auto_position=0;
主库的二进制文件名及当前备份的 position 编号记录在 /data/tmp/xtrabackup_slave_filename_info,如下图
复制下述语句时注意去除 MATSER_LOG_POS 后面值两边的单引号
CHANGE MASTER TO MASTER_LOG_FILE=’mysql-bin.000409′, MASTER_LOG_POS=95322;
最后一步就是启动同步,并查看同步状态
start slave;
show slave status\G;
确认 Slave_IO_Running、Slave_SQL_Running 的值均为 Yes 即可,如下图所示
注意点
按照上述步骤操作完成后,mysql 这个库是不会和 RDS 同步的,也就意味着从库的账户和授权和 RDS 没有任何关系,原因为恢复后 slave 的配置中配置忽略 mysql 库,如下图所示