实例:同步阿里云RDS库到自建mysql库
时间:2025-02-04 10:33:27 302浏览 收藏
文章小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《实例:同步阿里云RDS库到自建mysql库》带大家来了解一下##content_title##,希望对大家的知识积累有所帮助,从而弥补自己的不足,助力实战开发!
本文介绍如何在Ubuntu 14.04系统上,将阿里云RDS MySQL 5.6数据库同步到本地MySQL 5.6数据库。
一、准备工作:
环境:阿里云RDS MySQL 5.6,本地环境Ubuntu 14.04,MySQL 5.6。
二、安装Percona Xtrabackup:
wget https://repo.percona.com/apt/percona-release_0.1-5.$(lsb_release -sc)_all.deb
dpkg -i percona-release_0.1-5.$(lsb_release -sc)_all.deb
apt-get update
apt-get install percona-xtrabackup-24
三、安装MySQL服务和客户端:
apt-get install mysql-server-5.6 mysql-client-5.6
/etc/init.d/mysql stop
四、下载RDS数据库备份文件:
wget -c '' -O rds_backup.tar.gz # 请替换空字符串为你的RDS备份文件下载链接
五、解压备份文件:
将备份文件解压到指定目录(例如/home/mysql/data
,请根据实际情况修改)。
bash rds_backup_extract.sh -f rds_backup.tar.gz -C /home/mysql/data # 请确保rds_backup_extract.sh脚本可用
六、恢复数据库:
使用innobackupex
恢复解压后的备份文件。
innobackupex --defaults-file=/home/mysql/data/backup-my.cnf --apply-log /home/mysql/data
七、配置backup-my.cnf
文件:
编辑/home/mysql/data/backup-my.cnf
文件,根据你的RDS配置调整参数。以下提供一个示例,请根据实际情况修改:
[mysqld]
innodb_checksum_algorithm=innodb
innodb_data_file_path=ibdata1:200M:autoextend
innodb_log_files_in_group=2
innodb_log_file_size=1048576000
innodb_page_size=16384
innodb_undo_directory=.
innodb_undo_tablespaces=0
八、修改文件属主:
chown -R mysql:mysql /home/mysql/data
九、启动MySQL进程:
mysqld_safe --defaults-file=/home/mysql/data/backup-my.cnf --user=mysql --datadir=/home/mysql/data
十、清理MySQL系统表:
mysql -uroot
mysql> delete from mysql.db where user='root' and char_length(user)>0;
mysql> delete from mysql.tables_priv where user='root' and char_length(user)>0;
mysql> flush privileges;
mysql> use mysql;
mysql> drop table slave_master_info;
mysql> drop table slave_relay_log_info;
mysql> drop table slave_worker_info;
mysql> drop table innodb_index_stats;
mysql> drop table innodb_table_stats;
mysql> source /usr/share/mysql/mysql_system_tables.sql;
mysql> quit;
mysqladmin shutdown;
十一、配置my.cnf
文件:
将backup-my.cnf
中的必要参数复制到/etc/mysql/my.cnf
文件中,并根据你的实际情况进行调整。 请特别注意server-id
,gtid-mode
等参数的设置,以及数据库复制相关的配置。
十二、设置slave并进行同步 (请在阿里云RDS控制台创建一个只读用户用于同步):
- 重启MySQL服务:
/etc/init.d/mysql restart
- 获取
xtrabackup_slave_info
文件内容:cat /home/data/mysql/xtrabackup_slave_info
- 使用获取到的信息,执行以下SQL语句 (替换为你的RDS地址,用户名和密码):
mysql -uroot
mysql> SET GLOBAL gtid_purged='xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx:1-123456'; # 根据xtrabackup_slave_info文件内容修改
mysql> CHANGE MASTER TO MASTER_HOST='RDS外网地址', MASTER_PORT=3306, MASTER_USER='RDS同步账号', MASTER_PASSWORD='RDS同步密码', MASTER_AUTO_POSITION=1;
mysql> START SLAVE;
mysql> SHOW SLAVE STATUS \G;
十三、问题排查:
- InnoDB错误: 重启服务器。
- unknown variable: 在
my.cnf
中注释掉未知变量。 - Table crashed: 使用
myisamchk -c -r /home/mysql/data/db/tablesname.MYI
修复。 - 内存错误: 调整
my.cnf
中的内存相关参数。 - GTID错误 (1236): 获取RDS最新的备份文件重新同步。
注意: 以上步骤中的路径和参数需要根据你的实际情况进行调整。 在进行任何操作之前,请务必备份你的数据。 强烈建议在测试环境中先进行测试,再应用到生产环境。 部分参数的设置,可以参考阿里云RDS的配置,确保本地MySQL的配置与RDS尽可能一致。
本篇关于《实例:同步阿里云RDS库到自建mysql库》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
464 收藏
-
220 收藏
-
367 收藏
-
318 收藏
-
360 收藏
-
105 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习