一、安裝mysql,版本要和RDS實例的版本一致; 二、安裝mysql備份恢復工具percona-xtrabackup,下載地址爲
https://www.percona.com/downl...
三、rds上建立一個普通帳戶, 無需分配任何庫的權限,用於從庫同步使用;
四、添加ecs實例IP至RDS白名單;
五、下載RDS的全量備份至ECS實例,全量備份座標見下圖;
一、添加下述參數至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
三、恢復數據數據庫
innobackupex --apply-log /data/tmp/
innobackupex --copy-back /data/tmp/
四、修改mysql配置文件爲跳過受權,即添加下述配置至[mysqld]標籤下app
skip-grant-tables
以下圖所示工具
五、修改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;
八、修改root帳戶密碼orm
update mysql.user set password=password('Your_password') where user='root';
九、註釋或刪除跳過受權表的配置並從新啓動mysql,以下圖所示server
service mysqld restart
八、配置主從
再次登陸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庫,以下圖所示