MySQL--数据备份

备份方式

物理备份

使用物理备份对数据文件进行备份,备份的速度比较慢,占用的内存空间比较大,在恢复数据的时候比较迅速

逻辑备份

使用逻辑备份备份的是数据库的一些SQL语句,占用的内存空间比较少,但是在数据进行备份和恢复的时候所占用的时间比较长

物理备份

物理备份的方式

物理备份分为全量备份,增量备份和差异备份

全量备份是在数据库首次备份时进行的操作,然后增量备份是基于上一次的备份来进行备份的,每次备份所使用的内存空间比较小,但是在最后数据恢复的时候需要将第N次的备份文件都基于第一次全量备份的文件进行回滚,因此操作比较繁琐

差异部分第一次也是全量备份,在之后的每一次备份都是基于第一次备份文件进行备份,所以会有数据的冗余,每次产生的数据也相对来说比较大,要恢复第N天的数据时,只需要先将全量备份进行回滚,然后将对应第N天的备份也进行回滚,之后恢复数据即可

全量备份

bash 复制代码
innobackupex --user=root --password='密码' /xtrabackup/full

将现有数据库文件全部进行备份

恢复数据

bash 复制代码
innobackupex --apply-log 备份的文件路径
innobackupex --copy-back 备份的文件路径

增量备份

每次备份都是基于上一次备份目录文件进行

数据备份

先进行完整备份

bash 复制代码
innobackupex --user=root --password='密码' 文件路径

在基于完整备份进行增量备份

bash 复制代码
innobackupex -uroot -p'密码' --incremental 生成文件的目录 --incremental-basedir=基于全量备份的路径

再次基于上一次备份,进行增量备份

bash 复制代码
innobackupex -uroot -p'密码' --incremental 生成文件的目录 --incremental-basedir=基于前一天备份的路径
数据恢复

先回滚周一的全量备份

bash 复制代码
innobackupex --apply-log --redo-only 全量备份路径

在回滚周二的增量备份

bash 复制代码
innobackupex --apply-log --redo-only     全量复制路径  --incremental-dir=增量备份的路径

回滚周三的备份增量

bash 复制代码
innobackupex --apply-log --redo-only     全量复制路径  --incremental-dir=增量备份的路径
bash 复制代码
innobackupex --copy-back 全量复制文件路径

差异备份

每次备份都是基于第一次全量备份文件进行的

数据备份

第一次全量备份

bash 复制代码
innobackupex --user=root --password='密码' 备份路径

差异备份

bash 复制代码
 innobackupex --user=root --password=密码 --incremental /xtrabackup --incremental-basedir=全量备份的目录文件路径

差异备份每次进行备份时,都是基于第一次全量备份来进行的

数据恢复

先恢复第一次全量复制的文件

bash 复制代码
 innobackupex --apply-log --redo-only 全量复制文件路径

需要恢复第N天的数据,就使用第N天产生的差异备份文件基于全量复制文件进行恢复

bash 复制代码
innobackupex --apply-log --redo-only 第N天差异备份文件路径 --incremental-dir=第一天全量备份路径 

逻辑备份

使用mysqldump进行备份

语法:

sql 复制代码
mysqldump -u用户名 -p密码 库名 表名 > 文件名(通常.sql结尾)

选项:

-A 备份所有库

-B 备份多个数据库

-F 备份之前刷新binlog日志

--no-data 不导出数据,只导出表和库的结构

--lock-tables 备份前,锁定所有的库表

--single-transaction 保证数据的一致性和服务的可用性

-f --force 即使导入过程中出现错误,依旧进行数据导出,忽略错误

导出所有库
sql 复制代码
mysqldump -uroot -p用户密码 -A  > all.sql
导出单个库
sql 复制代码
mysqldump -uroot -p用户密码 db_name  > db_name.sql
导出多个库
导出库下的表
sql 复制代码
mysqldump -uroot -p用户密码 db_name tb_name > dbname_tbname.sql
仅导出库,表结构
bash 复制代码
mysqldump -uroot -p密码 --no-data db_name tb_name > db_name.tb_namedesc.sql
仅导出数据
bash 复制代码
select * from 表名 into outfile '文件名'; 
位于 /var/lib/mysql-files/
数据恢复
bash 复制代码
mysql -uroot -p密码 < sql文件
仅导入数据
sql 复制代码
load data infile '(文件名)/sql/test.t3.bak' into table t3(表名);
通过binlog日志恢复数据
bash 复制代码
mysqlbinlog --start-position 起始位置 --stop-position 结束位置 文件 | mysql -uroot -p密码
相关推荐
Java初学者小白6 分钟前
秋招Day14 - Redis - 应用
java·数据库·redis·缓存
帧栈31 分钟前
mysql基础(一)快速上手篇
mysql
丶意冷1 小时前
mybatisPlus分页方言设置错误问题 mybatisPlus对于Oceanbase的Oracle租户分页识别错误
java·数据库·oracle·oceanbase
时序数据说3 小时前
为什么时序数据库IoTDB选择Java作为开发语言
java·大数据·开发语言·数据库·物联网·时序数据库·iotdb
戒不掉的伤怀3 小时前
【Navicat 连接MySQL时出现错误1251:客户端不支持服务器请求的身份验证协议;请考虑升级MySQL客户端】
服务器·数据库·mysql
cv高级工程师YKY3 小时前
服务器 - - QPS与TPS介绍
数据库
nbsaas-boot3 小时前
高可扩展属性建模设计:架构师的全局思考与落地方案
数据库
爱上语文4 小时前
Redis基础(5):Redis的Java客户端
java·开发语言·数据库·redis·后端
陈敬雷-充电了么-CEO兼CTO4 小时前
推荐算法系统系列>推荐数据仓库集市的ETL数据处理
大数据·数据库·数据仓库·数据挖掘·数据分析·etl·推荐算法
MeshddY4 小时前
(超详细)数据库项目初体验:使用C语言连接数据库完成短地址服务(本地运行版)
c语言·数据库·单片机