如何优雅安全的备份MySQL数据

 更新时间:2022年10月11日 08:36:26   作者:一灯架构  
这篇文章主要介绍了如何优雅安全的备份MySQL数据的相关资料,需要的朋友可以参考下

1. 为什么要备份数据

先说一下为什么需要备份MySQL数据?

一句话总结就是:为了保证数据的安全性。

如果我们把数据只存储在一个地方,如果物理机器损坏,会导致数据丢失,无法恢复。

还有就是我们每次手动修改线上数据之前,为了安全起见,都需要先备份数据。防止人为的误操作,导致弄脏数据或弄丢数据。

2. 怎样备份MySQL数据?

想要快速简单粗暴备份MySQL数据,可以使用mysqldump命令:

# 备份test数据库
mysqldump -uroot -p test > backup.db

但是这样备份的可能包含脏数据,比如在我们备份数据的过程中,有个下单的操作正在执行。

下单之后,还没有来得及扣款,就开始执行备份数据的命令,就会出现脏数据。

下单,保存订单表
备份数据
扣款

3. 怎么安全的备份数据?

mysqldump命令也提供了以事务的形式备份的参数:

# 开启一个事务备份test数据库
mysqldump -uroot -p --single-transaction test > backup.db

开启事务后,会跟正常业务操作产生锁资源竞争,可能会阻塞其他的业务操作,严重的可能会导致服务宕机,所以备份操作尽量在业务低峰期执行。

还有一个问题,只有InnoDB引擎支持事务命令,对于不支持的事务MyISAM引擎,备份数据的时候怎么保证数据的安全性呢?

有一个粗暴的办法就是设置全库只读,禁止写操作,这样备份的时候不就能保证数据安全性啦。

先用命令查看一下数据库的只读状态:

show variables like 'read_only';

OFF表示只读模式关闭,ON表示开启只读模式。

set global read_only=1;

这样设置其实是非常危险的,如果客户端连接断开,整个数据库也会一直处于只读模式,无法进行写操作。

更推荐的办法是设置全局锁 FTWRL(flush tables with read lock)。

# 设置全局锁,禁止写操作
flush tables with read lock;
# 释放锁
unlock tables;

设置全局锁之后,如果客户端断开,会自动释放锁,更安全。

4. 怎么恢复数据?

通过备份文件恢复数据也非常简单:

# 把备份文件数据导入到test数据库
mysqldump -uroot -p test < backup.db

到此这篇关于如何优雅安全的备份MySQL数据的文章就介绍到这了,更多相关备份MySQL数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL聚簇索引和非聚簇索引的区别详情

    MySQL聚簇索引和非聚簇索引的区别详情

    这篇文章主要介绍了MySQL聚簇索引和非聚簇索引的区别详情,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下
    2022-06-06
  • Windows下MySQL5.6查找my.ini配置文件的方法

    Windows下MySQL5.6查找my.ini配置文件的方法

    今天小编就为大家分享一篇Windows下MySQL5.6查找my.ini配置文件的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-06-06
  • Mysql InnoDB引擎中的数据页结构详解

    Mysql InnoDB引擎中的数据页结构详解

    这篇文章主要为大家介绍了Mysql InnoDB引擎中的数据页结构详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • MySQL 常用引擎总结分享

    MySQL 常用引擎总结分享

    这篇文章主要介绍了MySQL 常用引擎总结分享,MySQL有很多存储引擎,所谓的存储引擎是指用于存储、处理和保护数据的核心服务,更多常用引擎分享,需要的小伙伴可以参考下面文章内容
    2022-06-06
  • mysql的group by使用及多字段分组

    mysql的group by使用及多字段分组

    Group By是一种SQL查询语句,常用于根据一个或多个列对查询结果进行分组,本文主要介绍了mysql的group by使用及多字段分组,感兴趣的可以了解一下
    2023-09-09
  • 详解MySQL的主从复制、读写分离、备份恢复

    详解MySQL的主从复制、读写分离、备份恢复

    本篇文章主要对MySQL的主从复制、读写分离、备份恢复进行详细全面的讲解,具有很好的参考价值,需要的朋友一起来看下吧
    2016-12-12
  • MySql如何使用not in实现优化

    MySql如何使用not in实现优化

    这篇文章主要介绍了MySql如何使用not in实现优化,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • MySQL的指定范围随机数函数rand()的使用技巧

    MySQL的指定范围随机数函数rand()的使用技巧

    这篇文章主要介绍了MySQL的指定范围随机数函数rand()的使用技巧,需要的朋友可以参考下
    2016-09-09
  • 教你为MySQL数据库换挡加速

    教你为MySQL数据库换挡加速

    如果你是个赛车手,并且按一下按钮就能够立即更换引擎而不需要把车开到车库里去换,那会是什么感觉呢?MySQL数据库为开发人员所做的就好像是按按钮换引擎;它让你选择数据库引擎,并给你一条简单的途径来切换它。
    2010-02-02
  • mysql死锁(dead lock)与锁等待(lock wait)的出现解决

    mysql死锁(dead lock)与锁等待(lock wait)的出现解决

    死锁和锁等待是数据库运维中常见的问题,区别在于死锁会自动解除,而锁等待需要手动处理,本文就来介绍一下mysql死锁(dead lock)与锁等待(lock wait),感兴趣的可以了解一下
    2024-09-09

最新评论