ECS實例搭建阿里雲RDS實例的從庫

準備工作

1、安裝mysql,版本要和RDS實例的版本一致; 2、安裝mysql備份恢復工具percona-xtrabackup,下載地址爲
https://www.percona.com/downl...
3、rds上創建一個普通賬戶,無需分配任何庫的權限,用於從庫同步使用;
4、添加ecs實例IP至RDS白名單;
5、下載RDS的全量備份至ECS實例,全量備份座標見下圖;

clipboard.png

從備份數據恢復

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

clipboard.png

3、恢復數據

innobackupex --apply-log /data/tmp/

clipboard.png

innobackupex --copy-back /data/tmp/

clipboard.png

4、修改mysql配置文件爲跳過授權,即添加下述配置至[mysqld]標籤下

skip-grant-tables

如下圖所示

clipboard.png

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;

clipboard.png

8、修改root賬戶密碼

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

clipboard.png

9、註釋或刪除跳過授權表的配置並重新啓動mysql,如下圖所示

clipboard.png

service mysqld restart

8、配置主從
再次登錄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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章