图解MySQL逻辑备份的实现流程

1. 摘要

数据作为一家公司的重要资产,其重要程度不言而喻。数据库为数据提供存取服务,担任着重要的角色,如果因数据误删、服务器故障、病毒入侵等原因导致数据丢失或服务不可用,会对公司造成重大损失,所以数据库备份是数据系统中最为重要的一环。

MySQL备份按照类型分为逻辑备份、物理备份、快照备份,本文将通过图文方式对常见的逻辑备份工具的一致性备份流程进行说明,来进一步了解逻辑备份的整个流程是怎么实现的。

2. 概念

逻辑备份是数据库对象级的备份,其将数据库里的对象通过SQL查询出来并转储到文件中,包含了用于创建转储对象(数据库,表,触发器、自定义函数、存储过程等)的CREATE语句,和用于将数据加载到表中的INSERT语句。

一致性备份是指在某个时间点,导出的数据与导出的备份文件信息匹配,如果导出了多张表的数据,这些不同表之间的数据都是同一个时间点的数据,MySQL可以通过全局锁(FTWRL,锁表备份)和事务(single-transaction,一致性快照)实现。

锁表备份在Server层实现,备份期间该实例只能进行SELECT操作;事务的一致性快照备份在引擎层实现,支持MVCC引擎表(InnoDB)的备份,期间实例可以对任何表进行DML操作,DDL操作需要根据具体情况分析,本文会对该情况(一致性快照备份)进行说明。

常见的逻辑备份工具:MySQL官方的mysqldumpmysqlpumpmysqlshell的dump方法和第三方开源的`mydumper。

3. 工具说明

3.1 mysqldump

说明:mysqldump使用单线程对表进行SELECT查询并转储到文件来达到备份的目的,作为MySQL最“古老”的备份工具,被广泛的使用在备份中。

  • 备份命令
mysqldump -udump_user -p -P3306 -h127.0.0.1 --master-data=2 --single-transaction --default-character-set=utf8 --all-databases --triggers --routines --events > all.sql
  • 备份流程

开启 general_log 查看备份流程,大致的备份流程如下图所示:

 

  • 流程说明
  1. 连接数据库,设置当前变量,刷脏页并加一个全局读锁,此刻数据库实例只能SELECT&
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值