首页 > 系统教程 > LINUX > 正文

实例:同步阿里云RDS库到自建mysql库

DDD
发布: 2025-02-03 23:32:19
原创
1224人浏览过

实例:同步阿里云rds库到自建mysql库

本文介绍如何在Ubuntu 14.04系统上,将阿里云RDS MySQL 5.6数据库同步到本地MySQL 5.6数据库。

一、准备工作:

环境:阿里云RDS MySQL 5.6,本地环境Ubuntu 14.04,MySQL 5.6。

二、安装Percona Xtrabackup:

<code class="bash">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</code>
登录后复制

三、安装MySQL服务和客户端:

<code class="bash">apt-get install mysql-server-5.6 mysql-client-5.6
/etc/init.d/mysql stop</code>
登录后复制

四、下载RDS数据库备份文件:

<code class="bash">wget -c '' -O rds_backup.tar.gz  # 请替换空字符串为你的RDS备份文件下载链接</code>
登录后复制

五、解压备份文件:

将备份文件解压到指定目录(例如/home/mysql/data,请根据实际情况修改)。

<code class="bash">bash rds_backup_extract.sh -f rds_backup.tar.gz -C /home/mysql/data # 请确保rds_backup_extract.sh脚本可用</code>
登录后复制

六、恢复数据库:

使用innobackupex恢复解压后的备份文件。

<code class="bash">innobackupex --defaults-file=/home/mysql/data/backup-my.cnf --apply-log /home/mysql/data</code>
登录后复制

七、配置backup-my.cnf文件:

编辑/home/mysql/data/backup-my.cnf文件,根据你的RDS配置调整参数。以下提供一个示例,请根据实际情况修改:

<code class="ini">[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</code>
登录后复制

八、修改文件属主:

<code class="bash">chown -R mysql:mysql /home/mysql/data</code>
登录后复制

九、启动MySQL进程:

<code class="bash">mysqld_safe --defaults-file=/home/mysql/data/backup-my.cnf --user=mysql --datadir=/home/mysql/data</code>
登录后复制

十、清理MySQL系统表:

<code class="sql">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;</code>
登录后复制

十一、配置my.cnf文件:

backup-my.cnf中的必要参数复制到/etc/mysql/my.cnf文件中,并根据你的实际情况进行调整。 请特别注意server-idgtid-mode等参数的设置,以及数据库复制相关的配置。

十二、设置slave并进行同步 (请在阿里云RDS控制台创建一个只读用户用于同步):

  1. 重启MySQL服务:/etc/init.d/mysql restart
  2. 获取xtrabackup_slave_info文件内容:cat /home/data/mysql/xtrabackup_slave_info
  3. 使用获取到的信息,执行以下SQL语句 (替换为你的RDS地址,用户名和密码):
<code class="sql">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;</code>
登录后复制

十三、问题排查:

  • 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库的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号