MySQL备份与恢复

数据备份的重要性

数据库备份的分类

物理备份:直接对数据库的物理文件(数据文件、日志文件等)进行备份

逻辑备份:对数据库对象(库、表)的数据以SQL语句的形式导出进行备份

备份策略

完全备份:每次备份都备份完整的库或表数据

差异备份:只备份上一次完全备份后的更新数据

增量备份:备份备份只备份上一次完全备份或增量备份后的更新数据

主要是完全备份增量备份配合使用

常见的备份方法

MySQL完全备份

优点:备份与恢复操作简单方便

缺点:数据存在大量重复

占用大量的备份空间

备份与恢复时间长

操作很简单,关闭mysql,tar打包data,数据被删除时,解压data重启mysql即可。

mysqldump完全备份

mysqldump 逻辑热备

mysqldump -u root -p密码 --databases 库1 库2 .... > XXX.sql #备份一个或多个指定的库及库中所有的表

mysqldump -u root -p密码 --all-databases > XXX.sql #备份所有库

mysqldump -u root -p密码 库名 > XXX.sql #只备份指定库中的所有表(不包含库对象本身)

mysqldump -u root -p密码 库名 表1 表2 .... > XXX.sql #只备份指定库中的一个或多个指定的表(不包含库对象本身)

完全恢复

1)先登录数据库,再执行 source sql文件路径 (如何sql文件里只备份了表,需要先 use 切换库再执行 source)

2)mysql -u root -p密码 < sql文件路径 cat sql文件路径 | mysql -u root -p密码 #恢复库

mysql -u root -p密码 库名 < sql文件路径 cat sql文件路径 | mysql -u root -p密码 库名 #恢复表

在命令控制行执行mysql命令

增量备份

增量备份相关的文件配置

在配置文件vim /etc/my.cnf配置

通过刷新二进制日志实现增量备份

mysqladmin -u root -p密码 flush-logs

查看二进制日志内容

mysqlbinlog --no-defaults --base64-output=decode-rows -v 二进制文件路径

使用二进制日志增量恢复

mysqlbinlog --no-defaults 二进制文件路径 | mysql -u root -p密码

断点恢复

基于位置点恢复

mysqlbinlog --no-defaults --start-position='开始位置点' --stop-position='结束位置点' 二进制文件路径 | mysql -u root -p密码

基于时间点恢复

mysqlbinlog --no-defaults --start-datetime='YYYY-mm-dd HH:MM:SS' --stop-datetime='YYYY-mm-dd HH:MM:SS' 二进制文件路径 | mysql -u root -p密码

断点恢复的原则:

如果要恢复到某条sql语句之前的所有数据,就stop在这个语句的位置点或时间点之前

如果要恢复某条sql语句及其之后的所有数据,就从这个语句的位置点或时间点开始start

脚本实现备份二进制日志

相关推荐
asdfg12589635 分钟前
一文通俗理解JDBC中的核心概念+案例
java·数据库·oracle·jdbc
点灯小铭12 分钟前
基于单片机与DAC0832的双路波形信号发生系统设计
数据库·单片机·mongodb·毕业设计·课程设计·期末大作业
小陈phd18 分钟前
Text2SQL智能体学习笔记(二)——NL2SQL落地的隐形基石:元数据库
数据库·笔记·学习
霸道流氓气质19 分钟前
阿里云 OSS 从零到实战:概念、配置与 Spring Boot 集成指南
数据库·spring boot·阿里云
茉莉玫瑰花茶20 分钟前
综合案例 - AI 智能租房助手 [ 4 ]
数据库·python·ai·langgraph
ULIi096kr22 分钟前
MySQL查看表创建时间、修改时间、最后更新时间(精准排查僵尸表)
数据库·mysql
折哥的程序人生 · 物流技术专研34 分钟前
Tomcat 严重警告:JDBC 驱动未注销 + 工作线程泄漏 —— 原因、影响与彻底修复(生产级终极指南)
java·运维·数据库·mysql·oracle·tomcat
初圣魔门首席弟子40 分钟前
Qt C++ 项目实战:修改共享头文件后的高效增量编译与快速发布流程
数据库
wb0430720141 分钟前
仓库搬家不停业——从阿明的“在线换仓库“,看数据库迁移与 Schema 演进的实战方法论
数据库·adb·架构
lx1885486989644 分钟前
Redis大Key阻塞:单线程CPU100%的致命陷阱
数据库·redis·缓存