MySQL--数据库备份

news2025/1/28 1:15:18

前言:本博客仅作记录学习使用,部分图片出自网络,如有侵犯您的权益,请联系删除

一、为什么要备份

  • 备份:能够防止由于机械故障以及人为误操作带来的数据丢失,例如将数据库文件保存在了其它地方。
  • 冗余: 数据有多份冗余,但不等备份,只能防止机械故障带来的数据丢失,例如主备模式、数据库 集群。

二、MySQL数据备份需要重视的内容

  • 备份内容:databasesBinlog my.cnf
  • 所有备份数据都应放在非数据库本地,而且建议有多份副本。
  • 测试环境中做日常恢复演练,恢复较备份更为重要。

备份过程必须考虑因素:

 1. 数据的一致性
 2. 服务的可用性
 Mysql A (读写) 压力比较大
 |
 Mysql B (读) 压力比较小 从节点做备份

三、MySQL备份类型

1、物理备份

直接复制数据库文件,适用于大型数据库环境,不受存储引擎的限制,但不能恢复到不同的MySQL版本。

(1)热备(hot backup)

在线备份数据库处于运行状态,这种备份方法依赖于数据库的日志文件;对应用基本无影响(但是性能还是会有下降,所以尽量不要在主库上做备份,在从库上做)

(2)冷备(cold backup)

备份数据文件,需要停机,是在关闭数据库的时候进行的;

  • 备份 datadir 目录下的所有文件

(3)温备(warm backup)

  • 针对myisam的备份(myisam不支持热备),备份时候实例只读不可写,数据库锁定表格(不可写入但可 读)的状态下进行的
  • 对应用影响很大
  • 通常加一个读锁

2、逻辑备份

备份的是建表、建库、插入等操作所执行SQL语句(DDL DML DCL),适用于中小型数据库,效率相对较低。

3、物理和逻辑备份的区别

逻辑备份物理备份
备份方式备份数据库建表、建库、插入sql备份数据库物理文件
优点语句备份文件相对较小,只备份表中的数据与结构恢复速度比较快
缺点恢复速度较慢(需要重建索引,存储过程等)备份文件相对较大(备份表空间,包含数据与索引)
对业务影响I/0负载加大I/O负载加大
代表工具mysqldumpibbackupxtrabackup

四、MySQL备份工具

 1、ibbackup
 官方备份工具;收费;物理备份
 ​
 2、xtrabackup
 开源社区备份工具;开源免费;物理备份
 ​
 3、mysqldump
 官方自带备份工具;开源免费;逻辑备份(速度慢)
 ​
 4、mysqlbackup
 mysql 官方备份工具;innodb 引擎的表mysqlbackup 可以进行热备;非innodb 表mysqlbackup 就只能温备;物理备份,备份还原速度快;适合大规模数据使用;

五、物理备份的方式

1、完全备份——完整备份

每次对数据进行完整的备份,即对整个数据库的备份、数据库结构和文件结构的备份,保存的是备份完成时刻的数据库,是差异备份与增量备份的基础。

优点:备份与恢复操作简单方便,恢复时一次恢复到位,恢复速度快

缺点:占用空间大,备份速度慢

2、增量备份

每次备份上一次备份到现在产生的新数据;只有那些在上次完全备份或者增量备份后被修改的文件才会被备份。以上次完整备份或上次的增量备份的时间为时间点,仅备份这之间的数据变化;

特点:因而备份的数据量小,占用空间小,备份速度快。但恢复时,需要从上一次的完整备份起按备份时间顺序,逐个备份版本进行恢复,恢复时间长,如中间某次的备份数据损坏,将导致数据的丢失。

3、差异备份

只备份跟完整备份不一样的;备份那些自从第一次次完全备份之后被修改过的所有文件,备份的时间起点是从第一次的完整备份起,且以 后每次备份都是和第一次完整备份进行比较(注意是第一次,不是上一次),备份自第一次完整备份以来所有的修改过的文件;备份数据量会越来越大;

特点:占用空间比增量备份大,比完整备份小,恢复时仅需要恢复第一个完整版本和最后一次的差异版本,恢复速度介于完整备份和增量备份之间。

六、percona工具

Xtrabackup 是开源免费的支持MySQL 数据库热备份的软件,在 Xtrabackup 包中主要有Xtrabackup innobackupex 两个工具。其中 Xtrabackup 只能备份 InnoDB 和 XtraDB 两种引擎; innobackupex则是封装了Xtrabackup,同时增加了备份MyISAM引擎的功能。它不暂停服务创建Innodb热备份;

Software Downloads - Percona

1、安装xtrackbackup

百度自行搜索;

(1)上传peronaRPM包

 # yum -y install percona-xtrabackup-24-2.4.5-1.el7.x86_64.rpm 

2、完全备份流程

 1、systemctl stop mysqld     # 关闭数据库
 2、mkdir /xtrabackup/        # 创建备份目录
 3、innobackupex --user=root --password=123 /xtrabackup/      # 备份
 4、innobackupex --apply-log /xtrabackup/<要恢复的目录>         # 准备恢复数据
 5、innobackupex --copy-back /xtrabackup/<要恢复的目录>         # 恢复数据
 6、chown mysql.mysql /data -R                                # 添加权限

具体示例演示:

 # 数据库备份
 [root@centos /]# innobackupex --user=root --password=123 /xtrabackup/
 # 备份完成,在/xtrabackup/目录下能看到备份好的目录
 [root@centos /]# cd /xtrabackup/
 [root@centos xtrabackup]# ls
 2024-07-26_15-41-02
 --------------------------------------------------------
 # 实验:删除数据库中的数据
 [root@centos /]# rm -rf /data/mysql/data/       # 删除完数据,可进入数据库查看库进行验证,开始恢复数据
 [root@centos /]# innobackupex --apply-log /xtrabackup/2024-07-26_15-41-02
 [root@centos /]# innobackupex --copy-back /xtrabackup/2024-07-26_15-41-02
 [root@centos /]# chown mysql.mysql /data -R # 恢复完成
 [root@centos /]# systemctl restart mysqld
 [root@centos /]# mysql
 mysql> show databases;

3、增量备份流程

基本语法:

 1、systemctl stop mysqld
 2、innobackupex --user=root --password=123 /xtrabackup/ # 完全备份
 3、innobackupex --user=root --password=123 --incremental /xtrabackup/ --incremental-basedir=/xtrabackup/完全备份的目录
 4、innobackupex --user=root --password=123 --incremental /xtrabackup/ --incremental-basedir=/xtrabackup/上一次增量的备份目录
 ​
 5、innobackupex --apply-log --redo-only /xtrabackup/全备目录
 6、innobackupex --apply-log --redo-only /xtrabackup/全备 --incremental-dir=/xtrabackup/要恢复的上一次增量目录
 7、innobackupex --copy-back /xtrabackup/全备

具体示例演示:

 [root@centos /]# innobackupex --user=root --password=123 /xtrabackup/   #全备 
 [root@centos /]# cd /xtrabackup     # 检查第一次全备目录
 [root@centos xtrabackup]# ls
 2024-07-26_16-54-18
 ​
 ​
 # 开始实验,创建周一sunday库
 mysql> create database sunday;
 # 第一次备份选用上个备份目录,这里即全备目录
 [root@centos /]# innobackupex --user=root --password=123 --incremental /xtrabackup/ --incremental-basedir=/xtrabackup/2024-07-26_16-54-18   
 # 查看目录,发现多了带有sunday库的目录
 [root@localhost xtrabackup]# ls             
 2024-07-26_16-54-18  2024-07-26_17-01-01
 ​
 ​
 # 再创建一个周二tuesday库
 mysql> create database tuesday;
 # 第二次增量备份选用上次目录,即从sunday库备份的目录
 [root@centos /]# innobackupex --user=root --password=123 --incremental /xtrabackup/ --incremental-basedir=/xtrabackup/2024-07-26_17-01-01   
 [root@localhost xtrabackup]# ls         # 查看,多出的目录即带有tuesday的备份目录
 2024-07-26_16-54-18  2024-07-26_17-01-01  2024-07-26_17-03-34
 ​
 # 增加权限并重启mysqld服务
 [root@centos /]# rm -rf /data/mysql/data
 [root@centos /]# chown -R mysql.mysql /data
 [root@centos /]# systemctl restart mysqld
 mysql> show databases;      # 检查数据库,发现无数据库;开始恢复
 [root@centos /]# innobackupex --apply-log --redo-only /xtrabackup/2024-07-26_16-54-18
 [root@centos /]# innobackupex --apply-log --redo-only /xtrabackup/全备 --incremental-dir=/xtrabackup/2024-07-26_17-03-34  # 这里选择恢复tuesday备份目录
 mysql> show databases;      # 检查数据库,发现数据库中连带monday库一起恢复
 +--------------------+
 | Database           |
 +--------------------+
 | information_schema |
 | monday             |
 | mysql              |
 | performance_schema |
 | sys                |
 | tuesday            |
 +--------------------+

4、差异备份流程

七、mysqldump逻辑备份

推荐优先使用

1、常用备份选项

 -A, --all-databases #备份所有库
 -B, --databases #备份多个数据库
 -F, --flush-logs #备份之前刷新binlog日志
 --default-character-set #指定导出数据时采用何种字符集,如果数据表不是采用默认的latin1
 字符集的话,那么导出时必须指定该选项,否则再次导入数据后将产生乱码问题。
 --no-data,-d #不导出任何数据,只导出数据库表结构。
 --lock-tables #备份前,锁定所有数据库表
 --single-transaction #保证数据的一致性和服务的可用性
 -f, --force #即使在一个表导出期间得到一个SQL错误,继续。

使用 mysqldump 备份数据库时避免锁表:

对一个正在运行的数据库进行备份请慎重!! 如果一定要在服务运行期间备份,可以选择添加 --single-transaction选项, 类似执行: mysqldump --single-transaction -u root -p123456 dbname > mysql.sql

2、备份表

 语法: # mysqldump -u root -p1 db1 t1 > /db1.t1.bak
 [root@mysql-server ~]# mkdir /home/back             # 创建备份目录
 [root@mysql-server ~]# mysqldump -uroot -p'qf123' company employee5 >
 /home/back/company.employee5.bak
 # 备份多个表:
 语法: mysqldump -u root -p1 db1 t1 t2 > /db1.t1_t2.bak
 [root@mysql-server ~]# mysqldump -uroot -p'qf123' company new_t1 new_t2 >
 /home/back/company.new_t1_t2.bak

3、备份库

 备份一个库:相当于将这个库里面的所有表全部备份。
 语法: # mysqldump -u root -p1 db1 > /db1.bak
 [root@mysql-server ~]# mysqldump -uroot -p'qf123' company >
 /home/back/company.bak
 备份多个库:
 语法:mysqldump -u root -p1 -B db1 db2 db3 > /db123.bak
 [root@mysql-server ~]# mysqldump -uroot -p'qf123' -B company testdb >
 /home/back/company_testdb.bak
 备份所有的库:
 语法:# mysqldump -u root -p1 -A > /alldb.bak
 [root@mysql-server ~]# mysqldump -uroot -p'qf123' -A > /home/back/allbase.bak

4、恢复数据库和表

为保证数据一致性,应在恢复数据之前停止数据库对外的服务,停止binlog日志 因为binlog使用binlog日志恢复数据时也会产生binlog日志。

为实验效果先将刚才备份的数据库和表删除了。登陆数据库:

 [root@mysql-server ~]# mysql -uroot -pqf123
 mysql> show databases;
 mysql> drop database company;
 mysql> \q

恢复库

 登陆mysql创建一个库
 mysql> create database company;
 恢复:
 [root@mysql-server ~]# mysql -uroot -p'qf123' company < /home/back/company.bak

恢复表

 登陆到刚才恢复的库中将其中的一个表删除掉
 mysql> show databases;
 mysql> use company
 mysql> show tables;
 +-------------------+
 | Tables_in_company |
 +-------------------+
 | employee5 |
 | new_t1 |
 | new_t2 |
 +-------------------+
 mysql> drop table employee5;
 开始恢复:
 mysql> set sql_log_bin=0; #停止binlog日志
 Query OK, 0 rows affected (0.00 sec)
 mysql> use company;
 mysql> source /home/back/company.employee5.bak; -------加路径和备份的文件
 恢复方式二:
 # mysql -u root -p1 db1 < db1.t1.bak
 库名 备份的文件路径
 [root@mysql-server ~]# mysql -uroot -p'qf123' company <
 /home/back/company.employee5.bak

5、备份及恢复表结构

备份 linux中执行

 mysqldump -uroot -p123 库 > 备份路径     
 mysqldump -uroot -p123 库 表1 表2 > 备份路径   # 备份一个库里的多张表
 mysqldump -uroot -p123 -B 库1 库2 > 备份路径  # 备份多个库
 mysqldump -uroot -p123 -A > 备份路径    # 备份所有数据

还原

 mysql -uroot -p 库 < 备份数据    # 恢复单个库需要手动创建库
 mysql -uroot -p  < 备份数据     # 如果还原多个库或者所有数据,无需手动创建库

seuce还原

在数据库中,执行 source 备份文件

备份恢复表结构

 1.备份表结构:
 语法:mysqldump -uroot -p123456 -d database table > dump.sql
 [root@mysql-server ~]# mysqldump -uroot -p'qf123' -d company employee5 >
 /home/back/emp.bak
 恢复表结构:
 登陆数据库创建一个库
 mysql> create database t1;
 语法:# mysql -u root -p1 -D db1 < db1.t1.bak
 [root@mysql-server ~]# mysql -uroot -p'qf123' -D t1 < /home/back/emp.bak

通过binlog日志恢复数据

  • 先开启binl 重启服务
  • 查看正在使用的binlog,找到binlog日志 /data/mysql/data /var/lib/mysql /usr/local/mysql
  • 找到想要恢复数据的偏移量
  • linux下,mysqlbinlog --start-position 844899 --stop-position 844994 137.000003 |mysql -uroot
  • 在数据库中查看数据是否恢复

致谢

在此,我要对所有为知识共享做出贡献的个人和机构表示最深切的感谢。同时也感谢每一位花时间阅读这篇文章的读者,如果文章中有任何错误,欢迎留言指正。 

学习永无止境,让我们共同进步!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1977655.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

AISOO爱数AnyShare/易享云-文档云数据恢复-2024.8.4

故障简述 一台数AnyShare的数据磁盘因物理故障&#xff0c;导致超过300GB企业文档资料远程访问。 客户在当地A数据恢复公司开盘恢复数据&#xff0c;但AnyShare的底层数据特有元数据信息&#xff0c;A恢复公司未能恢复此元数据信息&#xff0c;所以AnyShare极无法访问丢失的企…

栈和队列——4.前k个高频元素

力扣题目链接 给定一个非空的整数数组&#xff0c;返回其中出现频率前 k 高的元素。 示例&#xff1a; 输入&#xff1a;nums [1,1,1,2,2,3], k 2 输出&#xff1a;[1,2] 题干很简单&#xff0c;就是对数组中的元素进行频次计算&#xff0c;找到频次最多的前k和元素。那么…

48天笔试训练错题——day37

目录 选择题 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 编程题 1. 数据库连接池 2. mkdir 选择题 1. 2. 数据的五元组&#xff1a;源IP&#xff0c;源端口&#xff0c;目的IP&#xff0c;目的端口&#xff0c;协议。 源IP&#xff1a;描述数据从哪个主机上产生。 目的I…

南京观海微电子----单通道遥控开关电路原理及制作

本文介绍的遥控开关&#xff0c;具有遥控距离远&#xff08;大于30米&#xff09;&#xff0c;无方向限制&#xff0c;可穿透墙壁&#xff0c;工作稳定&#xff0c;体积小巧等优点。只要在家电设备的供电回路中加入这种电路&#xff0c;便能使家电具有遥控功能。下面分别介绍它…

『python爬虫』beautifulsoup库获取文本的方法.get_text()、.text 和 .string区别(保姆级图文)

目录 区别.string(不推荐用).text(get_text的简化版少敲代码的时候用).get_text(推荐用,功能强大,为什么不爱呢?) 示例代码总结 欢迎关注 『python爬虫』 专栏&#xff0c;持续更新中 欢迎关注 『python爬虫』 专栏&#xff0c;持续更新中 区别 省流直接看get_text 推荐用这个…

[BJDCTF2020]Cookie is so stable1

打开题目 查看页面源码 点击hint查看源码 提示看cookie&#xff0c;burp抓包查看cookie 试一下 尝试{{7*7}}&#xff0c;发现ssti漏洞&#xff0c;判断是twig 抓包&#xff0c;发现user为注入点 输入payload {{_self.env.registerUndefinedFilterCallback("exec"…

.NET 8 通用权限框架 前后端分离,开箱即用

目录 前言​ 项目介绍 1、支持各种数据库 2、前端运行步骤 3、演示环境 4、项目地址 5、在线文档 项目使用 项目功能 项目截图 总结 前言​ 推荐一个基于.NET 8 实现的通用权限开发框架Admin.NET&#xff0c;前端使用Vue3/Element-plus开发。 基于.NET 8(Furion)/Sq…

【中项】系统集成项目管理工程师-第9章 项目管理概论-9.9价值交付系统

前言&#xff1a;系统集成项目管理工程师专业&#xff0c;现分享一些教材知识点。觉得文章还不错的喜欢点赞收藏的同时帮忙点点关注。 软考同样是国家人社部和工信部组织的国家级考试&#xff0c;全称为“全国计算机与软件专业技术资格&#xff08;水平&#xff09;考试”&…

十分钟速通 Vue 动态 Class、Style

计算属性 大家有没有思考过这样一个问题&#xff0c;下面这段代码&#xff0c;功能上没什么问题&#xff0c;但是读起来很费劲&#xff0c;因为需要思考过后&#xff0c;才能知道这段代码的意思。 <p>{{ message.split().reverse().join() }}</p>这完全不符合面向…

[NISACTF 2022]ezpie- 入土为安的第十五天

pwn的第3天 PIE保护ret2text栈 按照签到题的套路是找main&#xff0c;buf,shell,bin/sh/ 但是是PIE保护 那有什么不一样的呢 PIE保护&#xff1a; ​ PIE全称是position-independent executable&#xff0c;中文解释为地址无关可执行文件&#xff0c;该技术是一个针对代码…

C++ | (一)C++入门基础

从本篇文章开始&#xff0c;我们正式进行C的系统学习。C是在C语言的基础上添加了面向对象编程的特性&#xff0c;是C语言的延伸&#xff0c;并遵循C语言的绝大多数语法。如果想学习C&#xff0c;必须要有一定的C语言基础&#xff0c;这样学起来才不会太过痛苦。 本文章即假设读…

Vue分析脚手架结构

1.分析结构 <!DOCTYPE html> <html lang""><head><meta charset"utf-8"><!-- 针对IE浏览器 得一个特殊配置&#xff0c;含义是让IE浏览器以最高得渲染级别渲染页面 --><meta http-equiv"X-UA-Compatible" cont…

吃瓜用户看广告获取密码访问网页内容流量主模式源码

用户看广告获取密码访问网页内容&#xff0c;网站生成内容&#xff0c;用户需要浏览内容跳转至小程序&#xff0c;观看广告后获取密码&#xff0c;输入密码查看网页内容。 与之前得9.9付费进群区别就是内容体现在了网页里&#xff0c;用户不需要进群查看。并且不需要付费&…

HTML 基础结构

目录 1. 文档声明 2. 根标签 3. 头部元素 4. 主题元素 5. 注释 6. 演示 1. 文档声明 <!DOCTYPE html>&#xff1a;声明文档类型&#xff0c;表示该文档是 html 文档&#xff0c; 2. 根标签 &#xff08;1&#xff09;所有的其他标签都要放在一对根标签中&#…

MySQL精简笔记

基础类型 整型&#xff1a;bit&#xff0c;tinyint&#xff0c;smallint&#xff0c;int&#xff0c;bigint浮点&#xff1a;fload&#xff0c;double&#xff08;M&#xff1a;整数小数的位数&#xff0c;D&#xff1a;小数的位数&#xff09;无符号&#xff1a; decimal&…

C++类和对象知识巩固:相关习题解析

目录 1&#xff0c;求下面析构的顺序 2&#xff0c;以下调用了多少次拷贝构造 3&#xff0c;计算日期到天数的转换 4&#xff0c;日期差值 5&#xff0c;打印日期 6&#xff0c;累加天数 7&#xff0c;求123...n&#xff0c;要求不能使用乘除法、for、while、if、else、…

springboot2自定义starter

1.创建maven项目。首先根据springboot 约定规范&#xff0c;Starter项目的命名规范如下&#xff1a; 建议自定义的starter 以 xxx-spring-boot-starter 命名&#xff0c;官方的Starter一般都是以spring-boot-starter-为前缀。这样做的目的是为了避免与官方或其他第三方提供的St…

C#-读取测序数据的ABI文件并绘制svg格式峰图

本地环境&#xff1a;win10&#xff0c;visual studio 2022 community 目录 前言问题描述实现效果解决思路实现要点ABI文件的组织方式svg绘制问题变色碱基值 动态设置svg图像宽度 前言 本文是在已有的代码基础上进行的开发&#xff0c;前期已经实现&#xff1a; ABI文件的解析…

8090怀旧视频素材去哪里找?怀旧童年的素材库分享给你

在这个充满活力的现代社会中&#xff0c;对80和90年代的复古风情的怀旧情感愈加浓厚。那些年的音乐、电影、日常生活乃至街头巷尾的景象&#xff0c;总能唤起人们的美好回忆。对于视频创作者而言&#xff0c;制作一部带有80和90年代怀旧风格的视频&#xff0c;不仅能触动观众的…

cgroup:Linux的资源控制机制

文章目录 1 cgroup 的主要功能1.1 资源限制1.2 优先级控制1.3 资源隔离1.4 资源监控 2 cgroup 的层次结构3 cgroup 子系统4 示例&#xff1a;使用 cgroup 控制 CPU 和内存4.1 创建 cgroup4.2 设置资源限制4.3 将进程添加到 cgroup 5 使用 systemd 管理 cgroup6 总结参考链接封面…