ECS实例搭建阿里云RDS实例的从库

准备工做

一、安装mysql,版本要和RDS实例的版本一致; 二、安装mysql备份恢复工具percona-xtrabackup,下载地址为
https://www.percona.com/downl...
三、rds上建立一个普通帐户, 无需分配任何库的权限,用于从库同步使用;
四、添加ecs实例IP至RDS白名单;
五、下载RDS的全量备份至ECS实例,全量备份坐标见下图;

clipboard.png

从备份数据恢复

一、添加下述参数至mysql配置文件的[mysqld]标签下;mysql

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

二、解压下载的全量备份至临时目录,本身能够随意指定,本文指定为/data/tmpsql

clipboard.png

三、恢复数据数据库

innobackupex --apply-log /data/tmp/

clipboard.png

innobackupex --copy-back /data/tmp/

clipboard.png

四、修改mysql配置文件为跳过受权,即添加下述配置至[mysqld]标签下app

skip-grant-tables

以下图所示工具

clipboard.png

五、修改mysql数据文件夹的属主为mysql用户,个人mysql数据是放在/data/mysql,若是不特殊指定的话是在/var/lib/mysqlspa

chown -R mysql. /data/mysql

六、启动mysql服务rest

service mysqld start

七、清空mysql库下的slave相关表信息code

use mysql;
truncate slave_gtid_info;
truncate slave_master_info;
truncate slave_relay_log_info;
truncate slave_worker_info;

clipboard.png

八、修改root帐户密码orm

update mysql.user set password=password('Your_password') where user='root';

clipboard.png

九、注释或删除跳过受权表的配置并从新启动mysql,以下图所示server

clipboard.png

service mysqld restart

八、配置主从
再次登陆mysql数据库时请指定-h 127.0.0.1

clipboard.png

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;

clipboard.png

最后一步就是启动同步,并查看同步状态

start slave;
show slave status\G;

确认Slave_IO_Running、Slave_SQL_Running的值均为Yes便可,以下图所示
clipboard.png

注意点

按照上述步骤操做完成后,mysql这个库是不会和RDS同步的,也就意味着从库的帐户和受权和RDS没有任何关系,缘由为恢复后slave的配置中配置忽略mysql库,以下图所示

clipboard.png

相关文章
相关标签/搜索