RDS FOR MYSQL 各版本利用物理备份搭建从库方法

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: RDS FOR MYSQL 各版本利用物理备份搭建从库方法,5.6,5.7

下面文档讲述RDS FOR MYSQL 各版本利用物理备份搭建从库方法:

说明:暂时包含RDS for mysql5.6和5.7版本的复制搭建过程:


1. 本地自建Mysql数据必须和云mysql版本大版本保持一致
2. 64位的Linux系统
3. MySQL 5.6及之前(含5.5)的版本需要安装 Percona XtraBackup 2.3 ; MySQL 5.7版本需要安装 Percona XtraBackup2.4
4. 为了快速恢复,本地mysql安装都采用centos的yum安装方式

5.注意下面没有说明哪个版本执行的就是都需要执行的

6.搭建复制环境前需要保证ECS能够访问的通RDS,建议用RDS内网地址进行复制搭建


5.6恢复示例:

安装mysql:
下面演示的是基于centos6系统的,centos7的见后面相关部分
1.下载yum源
centos6下安装:
wget 
https://repo.mysql.com//mysql80-community-release-el6-1.noarch.rpm
yum localinstall mysql80-community-release-el6-1.noarch.rpm -y
centos7下安装: wget  https://repo.mysql.com//mysql80-community-release-el7-1.noarch.rpm yum localinstall mysql80-community-release-el7-1.noarch.rpm
2.配置yum源

yum -y install yum-utils


#根据选择安装需要的版本

yum-config-manager --disable   mysql80-community  默认是安装8.0版本的mysql需要关闭这个yum源

yum-config-manager --enable   mysql57-community  恢复5.7版本就执行这条 5.7执行
yum-config-manager --enable   mysql56-community   如果是恢复5.6版本执行这条 5.6执行
3.安装mysql server (yum安装完成后不慌启动mysql) yum -y install mysql-community-server
4.替换/etc/my.cnf文件内容为以下内容,其中跳过权限表启动:
[mysqld] innodb_checksum_algorithm=crc32 innodb_data_file_path=ibdata1:200M:autoextend innodb_log_files_in_group=2 innodb_log_file_size=524288000 innodb_undo_directory=/var/lib/mysql/ basedir=/usr datadir=/var/lib/mysql innodb_undo_tablespaces=0 server_id=55555 log_bin=mysql-log gtid_mode=on enforce_gtid_consistency=on log-slave-updates=1 relay_log=relay-log sql_mode='' binlog_format=row skip-grant-tables=1

注意: server_id可以自己改,务必不要和RDS的一样了。
1).配置yum源

yum -y install
http://www.percona.com/downloads/percona-release/redhat/0.1-3/percona-release-0.1-3.noarch.rpm
2). 查看yum源,选择要安装的软件

yum list | grep percona
yum -y install percona-xtrabackup-24.x86_64   5.7版本需要安装这个
yum -y install percona-xtrabackup.x86_64        5.6版本需要安装这个

6.下载备份文件并恢复:
注意: 1.要做物理备份的恢复最好临时RDS控制台做个物理备份,备份做好后下载备份文件并恢复(如果用以前的备份可能导致二进制日志已经被清理了无法获取二进制日志进而复制环境搭建失败) 2. 要下载备份和配置主从关系,需要把当前ECS的内网IP加入到RDS的白名单里面
wget -c '
rds备份文件下载地址' -O bak.tar.gz     这个到RDS控制台备份恢复里面去获取备份集下载地址,注意下载地址这里用wget下载需要用单引号引起来,否则会报403错误
tar -izxvf bak.tar.gz    -C   /var/lib/mysql       在下载的备份文件目录执行解压,-C指定解压到/var/lib/mysql目录,因为yum安装的datadir是这个

cd  /var/lib/mysql
innobackupex --defaults-file=backup-my.cnf --apply-log /var/lib/mysql
chown -R mysql:mysql /var/lib/mysql
/etc/init.d/mysqld start
更新aliyun_root@127.0.0.1密码:
mysql     #shell里面执行mysql连接mysql并修改密码
mysql>select user,host from mysql.user;   查看是否有aliyun_root@127.0.0.1这个用户,可根据需要来设置根据这个sql查看到有的账号密码

mysql>flush privileges; mysql>SET PASSWORD FOR 'aliyun_root'@'127.0.0.1' = PASSWORD('MyNewPass'); 5.7版本是aliyun_root@127.0.0.1 mysql>SET PASSWORD FOR 'root'@'127.0.0.1' = PASSWORD('MyNewPass');  5.6版本是'root'@'127.0.0.1' mysql>exit

删除/etc/my.cnf里面的skip-grant-tables=1​​​​​​ /etc/init.d/mysqld restart

账号也迁移过来了的,可以用账号云mysql的账号登陆了:

登陆:

mysql -ualiyun_root -h127.0.0.1 -pMyNewPass       5.7执行
mysql -uroot -h127.0.0.1 -pMyNewPass       5.6执行
mysql>use mysql;  5.6执行
mysql>drop table slave_master_info;    5.6执行
mysql>drop table slave_relay_log_info;   5.6执行
mysql>drop table slave_worker_info;    5.6执行
mysql>drop table innodb_index_stats;   5.6执行 
mysql>drop table innodb_table_stats;    5.6执行mysql>source /usr/share/mysql/mysql_system_tables.sql;  5.6执行 mysql>exit /etc/init.d/mysqld restart 5.6版本必须重启,切记执行 查看/var/lib/mysql/xtrabackup_slave_info 里面的set global gtid_purged语句,把这个copy到后面复制用 6965d77ed715c97e2e0fdec7168853d1a61cf219mysql -uroot -h127.0.0.1 -pMyNewPass       5.6执行 mysql>reset master;   5.6执行 mysql>set global gtid_purged=xxx 上面截图的复制过来执行一次  5.6执行 5d621215d53462646f214a97636888884875d594
mysql>reset slave;
mysql>change master to master_host = 'rm-xxxxx.mysql.rds.aliyuncs.com', master_port = 3306, master_user = 'sadmin', master_password='Mypassword', master_auto_position = 1;
mysql>start slave;
mysql>show slave status\G
注意:上面的master_host  master_port  master_user  master_password 根据RDS主库的信息各自填写自己的信息,不要照着上面执行; 搭建完成show slave status\G看到的结果应该如下,slave io/sql线程都是YES状态: mysql> show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: rm-xxxxx.mysql.rds.aliyuncs.com
                  Master_User: hkadmin
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000245
          Read_Master_Log_Pos: 391176
               Relay_Log_File: relay-log.000002
                Relay_Log_Pos: 1588
        Relay_Master_Log_File: mysql-bin.000245
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes

              Replicate_Do_DB:
          Replicate_Ignore_DB:
           Replicate_Do_Table:
       Replicate_Ignore_Table:
      Replicate_Wild_Do_Table:
  Replicate_Wild_Ignore_Table:
                   Last_Errno: 0
                   Last_Error:
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 391176
              Relay_Log_Space: 1789
              Until_Condition: None
               Until_Log_File:
                Until_Log_Pos: 0
           Master_SSL_Allowed: No
           Master_SSL_CA_File:
           Master_SSL_CA_Path:
              Master_SSL_Cert:
            Master_SSL_Cipher:
               Master_SSL_Key:
        Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error:
               Last_SQL_Errno: 0
               Last_SQL_Error:
  Replicate_Ignore_Server_Ids:
             Master_Server_Id: 999098802
                  Master_UUID: a23bf85f-f20b-11e8-8268-7cd30abda240
             Master_Info_File: /var/lib/mysql/master.info
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: Slave has read all relay log; waiting for more updates
           Master_Retry_Count: 86400
                  Master_Bind:
      Last_IO_Error_Timestamp:
     Last_SQL_Error_Timestamp:
               Master_SSL_Crl:
           Master_SSL_Crlpath:
           Retrieved_Gtid_Set: a23bf85f-f20b-11e8-8268-7cd30abda240:493276-493279
            Executed_Gtid_Set: 937ca3af-f20b-11e8-9447-7cd30ab8a5d8:1-178841,
a23bf85f-f20b-11e8-8268-7cd30abda240:1-493279
                Auto_Position: 1
         Replicate_Rewrite_DB:
                 Channel_Name:
           Master_TLS_Version:
1 row in set (0.00 sec)

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
9天前
|
关系型数据库 MySQL 数据库
mysql卸载、下载、安装(window版本)
mysql卸载、下载、安装(window版本)
|
30天前
|
存储 关系型数据库 MySQL
RDS MySQL 数据库运维简述
从运维的视角,汇总云数据库RDS MySQL使用的避坑指南。文章初版,维护更新,欢迎指点。
761 3
|
28天前
|
关系型数据库 MySQL 数据库
django4版本提示 django.db.utils.NotSupportedError: MySQL 8 or later is required (found 5.7.26)
在学习Django时,用户遇到`django.db.utils.NotSupportedError`,提示需要MySQL 8.0.25或更高版本,但其系统上是5.7.26。为解决这个问题,用户决定不升级MySQL,而是选择注释掉Django源码中的数据库版本检查。通过Python命令行找到Django安装路径,进入`db/backends/base/base.py`,注释掉`self.check_database_version_supported()`函数
89 0
|
19天前
|
SQL 关系型数据库 MySQL
【MySQL技术专题】「问题实战系列」深入探索和分析MySQL数据库的数据备份和恢复实战开发指南(8.0版本升级篇)
【MySQL技术专题】「问题实战系列」深入探索和分析MySQL数据库的数据备份和恢复实战开发指南(8.0版本升级篇)
93 0
|
28天前
|
关系型数据库 MySQL Serverless
RDS MySQL Serverless
阿里云新推出RDS MySQL Serverless,提供实时弹性资源,按需设置范围,自动适应负载变化,实现资源优化与成本降低。用户可通过控制台或API轻松创建实例,无缝应对低负载至高负载场景,实现自动弹性扩缩容。该服务适合各种云数据库应用场景,兼具成本优化和高灵活性。【2月更文挑战第29天】
32 1
|
2月前
|
关系型数据库 MySQL 数据安全/隐私保护
【极光系列】Windows安装Mysql8.0版本
【极光系列】Windows安装Mysql8.0版本
|
MySQL 关系型数据库 数据库
|
MySQL 关系型数据库 RDS
RDS for MySQL CPU 性能问题分析
RDS for MySQL CPU 性能问题分析 RDS for MySQL CPU 使用率高是使用 RDS for MySQL 实例过程中比较常见的一类性能问题。 由于实例 CPU 资源打满会直接导致业务受损,且问题发生过程迅速、临界时间短 统计采集困难、问题发生后统计指标呈反向曲线,加之日常运维过程中问题征兆容易被忽视,非常容易导致用户体感问题突然性强烈,因此在这里我们对 RDS for MySQL 的 CPU 使用率高的原因做一个比较详细的分析说明。
2225 0