mysql 备份

围巾🧣 2023年09月06日 397次浏览

备份MySQL数据?

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

mysql复制代码# 备份test数据库
mysqldump -uroot -p blessingskin > blessingskin.sql

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

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

  1. 下单,保存订单表
  2. 备份数据
  3. 扣款

安全的备份数据?

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

mysql复制代码# 开启一个事务备份test数据库
mysqldump -uroot -p --single-transaction test > backup.sql

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

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

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

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

mysql
复制代码show variables like 'read_only';

image-20221001174210965.png

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

mysql
复制代码set global read_only=1;

image-20221001174320631.png

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

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

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

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

恢复数据

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

mysql复制代码# 把备份文件数据导入到test数据库
mysqldump -uroot -p blessingskin < blessingskin.sql
或者
use blessingskin;
source blessingskin.sql;