Xtrabackup备份及恢复
来源:SegmentFault
时间:2023-02-24 14:00:16 484浏览 收藏
在数据库实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《Xtrabackup备份及恢复》,聊聊MySQL、Linux、xtrabackkup,希望可以帮助到正在努力赚钱的你。
Xtrabackup备份及恢复
一、主从数据库备份
1、环境
操作系统版本:linux-7.3-x86_64
数据库版本:mysql-5.7.19-x86_64
master主服务器: 172.22.23.14
slave从服务器: 172.22.23.15
mysql 5.7以下版本,可以采用percona xtrabackup 2.4版本
mysql 8.0以上版本,可以采用percona xtrabackup 8.0版本
下载路径 https://downloads.percona.com/downloads/Percona-XtraBackup-2.4/Percona-XtraBackup-2.4.21/binary/tarball/percona-xtrabackup-2.4.21-Linux-x86_64.glibc2.12.tar.gz tar -zxvf percona-xtrabackup-2.4.21-Linux-x86_64.glibc2.12.tar.gz mv percona-xtrabackup-2.4.21-Linux-x86_64.glibc2.12 /usr/local/xtrabackup ln -s /usr/local/xtrabackup/bin/* /usr/bin/ xtrabackup --version
2、主数据全量备份
将主数据库(172.22.23.14:20033)全量数据备份至目录/opt/backup下。
事先查看备份数据量
innobackupex --defaults-file=/etc/my.cnf --user=root --password=123456 --port=3306 --socket=/var/lib/mysql/mysql.sock /opt/backup
查看备份数据库数据量
`du -sh 2021-12-09_22-14-48/`
注意:全量备份时间与数据库数据量有关,700G备份时间大概40分钟。
进入目录/opt/backup查看是否备份成功:
为了保证备份集中的数据一致,需要操作:
innobackupex --apply-log /opt/backup/2021-12-09_22-14-48
3、复制数据至从数据库
df -hl:查看磁盘剩余空间
根据数据库数据量选择目录
将主数据库的全备复制到从数据库主机/opt/backup目录下:
cd /opt/backup
在当前的主服务器上做操作
scp –r /opt/backup/2021-12-09_22-14-48 root@172.22.143.199:/opt/backup/
4、从数据库服务重启
将从数据库上的MySQL停掉
然后将从主数据库复制的全量备份文件放到从数据库的datadir目录下:
mv /opt/backup/2021-12-09_22-14-48/* /var/lib/mysql/ cd /var/lib/mysql/ xtrabackup --defaults-file=/etc/my.cnf --prepare --target-dir=/var/lib/mysql/
Mysql及以下文件目录都改成mysql
chown -R mysql:mysql /var/lib/mysql
测试当前从服务器启动mysql:
Systemctl start mysqld
进入数据库:
Mysql –uroot –p123456
检查数据库数据是否与当前主服务器一致
出现的问题:ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
mysql.sock文件不在/tmp目录下,为该文件创建超链接。
ln -s /data1/opt/mysql_20033_ainote/mysql_20033_ainote.sock /tmp/mysql.sock
5、主从同步
查看备份集信息:
cat /var/lib/mysql/xtrabackup_binlog_info cat /var/lib/mysql/xtrabackup_binlog_pos_innodb
创建复制:
change master to master_host='172.22.23.14',MASTER_PORT = 20033, master_user='replicator', master_password='Rep1!C@T0r', master_log_file='mysql-bin.000560', master_log_pos=257293478; start slave;
查看复制信息:show slave status\G
问题:The replication receiver thread cannot start because the master has GTID_MODE = ON and this server has GTID_MODE = OFF.
处理:修改配置文件my.cnf。新增内容:
gtid_mode
gtid_mode = on
enforce_gtid_consistency = on
skip_slave_start = 1
然后停止数据库,重新刷新数据,启动数据库。
今天关于《Xtrabackup备份及恢复》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于mysql的内容请关注golang学习网公众号!
-
499 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
101 收藏
-
208 收藏
-
174 收藏
-
317 收藏
-
371 收藏
-
244 收藏
-
288 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习