快盘下载:好资源、好软件、快快下载吧!

快盘排行|快盘最新

当前位置:首页软件教程电脑软件教程 → mysql数据库备份与恢复 如何优雅的备份MySQL数据?

mysql数据库备份与恢复 如何优雅的备份MySQL数据?

时间:2022-10-11 10:08:20人气:作者:快盘下载我要评论
  1. 为什么要备份数据
    先说一下为什么需要备份mysql数据?

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

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

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

  1. 怎样备份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’;
mysql数据库备份与恢复 如何优雅的备份MySQL数据?

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

set global read_only=1;

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

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

设置全局锁;禁止写操作

flush tables with read lock;

释放锁

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

  1. 怎么恢复数据?
    通过备份文件恢复数据也非常简单;

把备份文件数据导入到test数据库

mysqldump -uroot -p test < backup.db

相关文章

  • 一步步带你设计MySQL索引数据结构

    一步步带你设计MySQL索引数据结构,想想我们生活中的例子,比如新华字典,我们有一个目录,目录根据拼音排序,内容包含了汉字位于字典中具体的的页码。聪明的你肯定也想到了,我们也可以借鉴这种思想,建立一个MySQL的目录,叫做“索引”。...
  • 影刀连接Mysql数据库

    影刀连接Mysql数据库,影刀配置连接mysql数据库基础版...

网友评论

快盘下载暂未开通留言功能。

关于我们| 广告联络| 联系我们| 网站帮助| 免责声明| 软件发布

Copyright 2019-2029 【快快下载吧】 版权所有 快快下载吧 | 豫ICP备10006759号公安备案:41010502004165

声明: 快快下载吧上的所有软件和资料来源于互联网,仅供学习和研究使用,请测试后自行销毁,如有侵犯你版权的,请来信指出,本站将立即改正。