当前位置:网站首页>MySQL数据库完全备份与增量备份怎么实现
MySQL数据库完全备份与增量备份怎么实现
2022-08-10 16:18:00 【亿速云】
MySQL数据库完全备份与增量备份怎么实现
这篇文章主要介绍“MySQL数据库完全备份与增量备份怎么实现”,在日常操作中,相信很多人在MySQL数据库完全备份与增量备份怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL数据库完全备份与增量备份怎么实现”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
定义
完全备份就是将数据库中的数据及所有对象全部备份。
由于 MySQL 服务器中的数据文件是基于磁盘的文本文件,所以完全备份就是复制数据库文件,是最简单也是最快速的方式。
但 MySQL 服务器的数据文件在服务器运行期间,总是处于打开状态,为实现真正的完全备份,需要先停止 MySQL 数据库服务器。
为了保障数据的完整性,在停止 MySQL 服务器之前,需要先执行 flush tables 语句将所有数据写入到数据文件中。对于该方法同学们只需了解,因为将生产环境下的数据库停下来做备份是不可取的。
使用 mysqldump 命令实现对表、数据库、数据库系统进行备份:
mysqldump [-h主机名] –u用户名 –p密码 --lock-all-tables --database [tables] > 文件名
-h 主机名,可省略,表示本地服务器,--lock-all-tables 对要备份的数据库的所有表施加读锁(在这个过程中,数据库严格处于 read only 状态),--database 后面可以加上需要备份的表,没有指定表名,则表示备份整个数据库。
完全备份与恢复演示
准备一张 student 表,将该表建在 world 数据库中。
建表:
CREATE DATABASE world;USE world;CREATE TABLE student( stuId INT(10) NOT NULL, stuName VARCHAR(10) NOT NULL, stuAge INT(10) NOT NULL, PRIMARY KEY(stuId) );
插入数据:
INSERT INTO student(stuId, stuName, stuAge) VALUES(1, 'zhangsan', 18), (2, 'lisi', 19),(3, 'wangwu', 18);

使用 flush tables; 语句将所有数据写入到数据文件中:
FLUSH TABLES;
退出 mysql 环境,使用 mysqldump 命令对数据库 world 进行完全备份:
mysqldump -u root -p --lock-all-tables --databases world > /tmp/world.sql
进入 /tmp 目录下,查看备份文件:
cd /tmpls
现在,我们对 world 这个库已经做了完全备份,不怕其数据丢失。
模拟 world 数据库中的 student 表丢失:
DROP TABLE student;
确认表被删除
SHOW TABLES;

使用 mysql 命令恢复数据库:
mysql -uroot -p < /tmp/world.sql
进入 mysql 环境,查看恢复结果:
SHOW TABLES;
输出结果:

验证表中数据:
SELECT * FROM student;

增量备份是对上次完全备份或增量备份以来改变了的数据进行备份,依赖二进制日志文件,需要开启数据库的 binlog 日志。先对数据库进行一次全量备份,备份同时将 binlog 日志刷新,在这次备份之后的所有操作都会记录在新增的 binlog 日志当中,我们只需要对增加的 binlog 进行备份,就实现了对不断增加内容的数据库的完美备份了。当数据库出现异常的时候,我们可以先恢复最近一次的全量备份,接着将增量备份的文件一个一个按顺序恢复即可实现数据库恢复。
到此,关于“MySQL数据库完全备份与增量备份怎么实现”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
边栏推荐
- Mobileye joins hands with Krypton to open a new chapter in advanced driver assistance through OTA upgrade
- 并发容器线程安全应对之道
- 视频转成gif动图怎么操作?仅需三步在线完成视频转gif
- Asterisk SIP media path
- 如何将jpg静图做成gif动图?教你1分钟快速合成gif
- Gif动图制作怎么在线操作?一招教你快速完成gif在线制作
- LeetCode-692. Top K Frequent Words
- 异形屏为led显示行业带来更多希望
- MS | 使用小技巧不完全总结
- 【21天学习挑战赛】直接选择排序
猜你喜欢

软件配置 | pip下载第三方库文件及配置pip源的不完全总结

Yi Gene|In-depth review: epigenetic regulation of m6A RNA methylation in brain development and disease

Bitwarden:免费、开源的密码管理服务

一文带你彻底拿下a,b两点间等效电阻

PNG如何变gif?教你一招png秒变gif动图的方法

从抖音到火山引擎——看流媒体技术演进和机会

MySQL的使用演示及操作,MySQL数据字符集的设置

如何将jpg静图做成gif动图?教你1分钟快速合成gif

Gif动图怎么用视频做?一键在线完成视频转gif制作

LabView---双通道示波器(内含信号发生器)
随机推荐
异形屏为led显示行业带来更多希望
怎么学自动化测试
rtsp 和 rtmp 推流(一)
数学基础(五)最优化理论(最优化,无约束,有约束,拉格朗日乘子的意义,KKT条件)
26、压缩及解压缩命令
自助服务知识库是什么?
cmake 小技巧 记录
简述 Mock 接口测试
力扣+牛客--刷题记录
FTXUI按键和ROS2 CLI组合使用笔记(turtlesim+teleop)
Qt 绘图和绘图设备
【FreeRTOS】13 动态内存管理
LeetCode-876. Middle of the Linked List
uniapp使用scroll-view,设置横向,内容重叠的问题解决
openpyxl绘制堆叠图
使用Jedis连接linux上的redis
困扰已久的一个微信bug
烟雾、空气质量、温湿度...自己徒手做个环境检测设备
glui.h无法找到描述+解决+测试
shell之正则表达式及三剑客awk命令