MySQL--数据库备份

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

一、为什么要备份

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

二、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、mysqlbackupmysql 官方备份工具;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]# ls2024-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 /]# mysqlmysql> show databases;

3、增量备份流程

基本语法:

 1、systemctl stop mysqld2、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]# ls2024-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 mysqldmysql> 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 -pqf123mysql> 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 companymysql> 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.rhkb.cn/news/391952.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

密码学基础:搞懂Hash函数SHA1、SHA-2、SHA3(2)

目录 1.引入 2. SHA512-224\256 3.SHA-3 4.MD5 5.SM3 1.引入 上篇密码学基础&#xff1a;搞懂Hash函数SHA1、SHA-2、SHA3(1)-CSDN博客&#xff0c;我们先就将基础的SHA1\2讲解了&#xff0c;接下来我们继续聊SHA-3、SHA2变体SHA512_224\256等 2. SHA512-224\256 SHA512…

TPS和QPS达到多少才算高并发?

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐&#xff1a;「storm…

pytorch学习笔记3 tensor索引和切片

dim 0 占先 切片 &#xff08;前N或者后N个&#xff09; &#xff1a;2 表示 0到2&#xff08;不包含2&#xff09;&#xff0c; 1&#xff1a;表示 1到末尾&#xff0c; -1表示最后一个元素&#xff0c;-2表示倒数第二个 0:28:2 表示从0到27隔点采样 &#xff1a;&#xff…

AC+AP组网

配置DHCP Switch1 <Huawei>sys [Huawei]undo in en [Huawei]vlan batch 10 20 30 40[Huawei]int vlan 10 [Huawei-Vlanif10]ip add 192.168.10.1 24 [Huawei-Vlanif10]quit[Huawei]int vlan 20 [Huawei-Vlanif20]ip add 192.168.20.1 24 [Huawei-Vlanif20]quit[Huawei]…

华水2022年专升本计算机培养方案

华水2022年专升本计算机培养方案 文章目录 华水2022年专升本计算机培养方案计科第一学期第二学期第三学期第四学期 软工第一学期第二学期第三学期第四学期 计科 第一学期 通识必修课 大学外语线性代数离散数学 专业基础课 高级语言程序设计 专业选修课 Java 第二学期 通识…

centos7安装zabbix

可以联网的centos7系统 关闭防火墙 selinux也关了 1、配置镜像源 wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo wget -O /etc/yum.repos.d/epel.repo https://mirrors.aliyun.com/repo/epel-7.repo2、安装nginx并配置 yum ins…

基于SpringBoot+Vue的科研管理系统(带1w+文档)

基于SpringBootVue的科研管理系统(带1w文档) 基于SpringBootVue的科研管理系统(带1w文档) 科研的管理系统设计过程中采用Java开发语言,B/S结构&#xff0c;采取springboot框架&#xff0c;并以MySql为数据库进行开发。结合以上技术&#xff0c;对本系统的整体、数据库、功能模块…

如何使用nodejs的fsPromise.access()判断文件权限

同学们可以私信我加入学习群&#xff01; 正文开始 一种错误示范fsPromise.access正确的书写总结 一种错误示范 我们操作文件的时候&#xff0c;经常需要提前判断文件的状态&#xff1a;文件是否存在、文件是否可读、文件是否可写。 查看官网介绍后&#xff0c;按照我们平时的…

数学建模评价类—Topsis法

目录 文章目录 前言 切记&#xff1a;以下内容仅用于参考理解&#xff0c;不可用于数模竞赛&#xff01;&#xff01;&#xff01; 一、Topsis的基本原理 二、Topsis的建模过程 1.判断矩阵是否需要正向化 2.原始矩阵正向化 3.矩阵标准化 4.计算距离&#xff0c;给出得…

FPGA的工作本科可以做吗?

在FPGA行业中&#xff0c;这样的偏见一直存在。 很多人认为&#xff0c;只有985、211的硕士才有资格涉足这一领域&#xff0c;甚至有人表示&#xff0c;即使是9、2本硕也难以找到工作&#xff0c;本科生就不要想了。 难到真的只有985&#xff0c;211的研究生才能有机会入行FPG…

安卓常用控件ListView

文章目录 ListView的常用属性ListView的常用APIListView的简单使用 ListView是一个列表样式的 ViewGroup&#xff0c;将若干 item 按行排列。它是一个很基本的控件也是 Android 中最重要的控件之一。它可以实现多个 View 的垂直排列并支持滚动显示效果。 ListView的常用属性 常…

农场游戏中的时间管理实例

一、准备工作 在Unity中创建承载日期和时间的文本 二、设置游戏的时间戳 using System.Collections; using System.Collections.Generic; using UnityEngine; //标识这个类可以被序列化 [System.Serializable] public class GameTimestamp {// 游戏时间戳的成员变量public in…

鸿蒙next 评分组件来了 我不允许你不会

前言导读 各位同学大家,有段时间没有跟大家见面了,因为最近一直在更新鸿蒙的那个实战课程所以就没有去更新文章实在是不好意思, 所以今天就给大家更新一期实战案例 评分组件 希望帮助到各位同学工作和学习 效果图 接口 Rating(options?: { rating: number, indicator?:…

48天笔试训练错题——day40

目录 选择题 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 编程题 1. 发邮件 2. 最长上升子序列 选择题 1. DNS 劫持又称域名劫持&#xff0c;是指在劫持的网络范围内拦截域名解析的请求&#xff0c;分析请求的域名&#xff0c;把审查范围以外的请求放行&#xff0c;否则返回…

开关电源之电压的影响因素和指标

开关电源并不是一个简单的小盒子&#xff0c;它相当于有源器件的心脏&#xff0c;不断地为元件提供能量。电源质量的好坏直接影响到元器件的性能。开关电源的设计、制造和质量管理需要精密的电子仪器来模拟电源的实际工作特性&#xff08;即各种规格&#xff09;&#xff0c;经…

docker、k8s部署 mysql group replication 和 ProxySQL 读写分离

MySQL Group Replication&#xff08;简称MGR&#xff09;是MySQL官方推出的一个高可用与高扩展的解决方案。MySQL组复制它提供了高可用、高扩展、高可靠的MySQL集群服务&#xff0c;这里部署的 mysql 版本 5.7.33&#xff0c;架构是一读一写。特别要注意一个关键点: 必须保证各…

Go语言加Vue3零基础入门全栈班10 Go语言+gRPC用户微服务项目实战 2024年07月31日 课程笔记

概述 如果您没有Golang的基础&#xff0c;应该学习如下前置课程。 Golang零基础入门Golang面向对象编程Go Web 基础Go语言开发REST API接口_20240728Go语言操作MySQL开发用户管理系统API教程_20240729Redis零基础快速入门_20231227GoRedis开发用户管理系统API实战_20240730Mo…

【数据结构算法经典题目刨析(c语言)】反转链表(图文详解)

&#x1f493; 博客主页&#xff1a;C-SDN花园GGbond ⏩ 文章专栏&#xff1a;数据结构经典题目刨析(c语言) 目录 一、题目描述 二、思路分析 三、代码实现 一、题目描述&#xff1a; 二、思路分析 &#xff1a; 通过三个指针n1,n2,n3来实现链表的反转 1.首先初始化 n1为…

指针函数和函数指针

文章目录 &#x1f34a;自我介绍&#x1f34a;指针函数&#x1f34a;指针函数回调函数 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以&#xff1a;点赞关注评论收藏&#xff08;一键四连&#xff09;哦~ &#x1f34a;自我介绍 Hello,大家好&#xff0c;我是小珑也要…

谷粒商城实战笔记-128-商城业务-商品上架-sku在es中存储模型分析-关键

文章目录 一&#xff0c;Elasticsearch在谷粒商城中的应用1&#xff0c;商城的商品检索2&#xff0c;日志检索 二&#xff0c;谷粒商城ES的商品索引mapping如何设计1&#xff0c;商品索引product的mapping冗余 SPU 信息的原因第一种方案的优缺点&#xff1a;优点&#xff1a;缺…