MySQL怎么保证备份数据的一致性


前言

为了数据安全,数据库需要定期备份,这个大家都懂,然而数据库备份的时候,最怕写操作,因为这个最容易导致数据的不一致,松哥举一个简单的例子大家来看下:

假设在数据库备份期间,有用户下单了,那么可能会出现如下问题:

  • 库存表扣库存。

  • 备份库存表。

  • 备份订单表数据。

  • 订单表添加订单。

  • 用户表扣除账户余额。

  • 备份用户表。

假如按照上述逻辑操作,备份文件中的订单表会缺失一条记录。如果使用该备份文件来恢复数据,会缺少一条记录,导致数据不一致。

为了解决这个问题,MySQL 中提供了很多方案,我们来逐一进行讲解并分析其优劣。

1. 全库只读

要解决这个问题,我们最容易想到的办法就是在数据库备份期间设置数据库只读,不能写,这样就不用担心数据不一致了,设置全库只读的办法也很简单,首先我们执行如下 SQL 先看看对应变量的值:

show variables like 'read_only';

MySQL怎么保证备份数据的一致性

可以看到,默认情况下,read_only 是 OFF,即关闭状态,我们先把它改为 ON,执行如下 SQL:

set global read_only=1;

1 表示 ON,0 表示 OFF,执行结果如下:

MySQL怎么保证备份数据的一致性

这个 read_only 对 super 用户无效,所以设置完成后,接下来我们退出来这个会话,然后创建一个不包含 super 权限的用户,用新用户登录,登录成功之后,执行一个插入 SQL,结果如下:

MySQL怎么保证备份数据的一致性

可以看到,这个错误信息中说,现在的 MySQL 是只读的(只能查询),不能执行当前 SQL。

加了只读属性,就不用担心备份的时候发生数据不一致的问题了。

但是 read_only 我们通常用来标识一个 MySQL 实例是主库还是从库:

  • read_only=0,表示该实例为主库。数据库管理员 DBA 可能每隔一段时间就会对该实例写入一些业务无关的数据来判断主库是否可写,是否可用,这就是常见的探测主库实例是否活着的。

  • read_only=1,表示该实例为从库。通常,对从库进行定期探活时,只会执行一些读操作,例如执行 "select 1;" 这样的语句。

所以,read_only 这个属性其实并不适合用来做备份,而且如果使用了 read_only 属性将整个库设置为 readonly 之后,如果客户端发生异常,则数据库就会一直保持 readonly 状态,这样会导致整个库长时间处于不可写状态,风险很高。

因此这种方案不合格。

2. 全局锁

全局锁,顾名思义,就是把整个库锁起来,锁起来的库就不能增删改了,只能读了。

那么我们看看怎么使用全局锁。MySQL 提供了一个加全局读锁的方法,命令是 flush tables with read lock (FTWRL)。当你需要让整个库处于只读状态的时候,可以使用这个命令,之后其他线程的增删改等操作就会被阻塞。

Mootion Mootion

Mootion是一个革命性的3D动画创作平台,利用AI技术来简化和加速3D动画的制作过程。

Mootion 232 查看详情 Mootion

MySQL怎么保证备份数据的一致性

从图中可以看到,使用 flush tables with read lock; 指令可以锁定表;使用 unlock tables; 指令则可以完成解锁操作(会话断开时也会自动解锁)。

和第一小节的方案相比,FTWRL 有一点进步,即:执行 FTWRL 命令之后如果客户端发生异常断开,那么 MySQL 会自动释放这个全局锁,整个库回到可以正常更新的状态,而不会一直处于只读状态。

但是!!!

加了全局锁,就意味着整个数据库在备份期间都是只读状态,那么在数据库备份期间,业务就只能停摆了。

所以这种方式也不是最佳方案。

3. 事务

不知道小伙伴们是否还记得松哥之前和大家分享的数据库的隔离级别,四种隔离级别中有一个是可重复读(REPEATABLE READ),这也是 MySQL 默认的隔离级别。

如果在该隔离级别下,用户在另一个事务中多次执行相同的 SELECT 语句,结果始终相同。(因为正在执行的事务所产生的数据变化不能被外部看到)。

换言之,在 InnoDB 这种支持事务的存储引擎中,那么我们就可以在备份数据库之前先开启事务,此时会先创建一致性视图,然后整个事务执行期间都在用这个一致性视图,而且由于 MVCC 的支持,备份期间业务依然可以对数据进行更新操作,并且这些更新操作不会被当前事务看到。

在可重复读的隔离级别下,即使其他事务更新了表数据,也不会影响备份数据库的事务读取结果,这就是事务四大特性中的隔离性,这样备份期间备份的数据一直是在开启事务时的数据。

具体操作也很简单,使用 mysqldump 备份数据库的时候,加上 -–single-transaction 参数即可。

为了看到 -–single-transaction 参数的作用,我们可以先开启 general_loggeneral_log 即 General Query Log,它记录了 MySQL 服务器的操作。当客户端连接、断开连接、接收到客户端的 SQL 语句时,会向 general_log 中写入日志,开启 general_log 会损失一定的性能,但是在开发、测试环境下开启日志,可以帮忙我们加快排查出现的问题。

通过如下查询我们可以看到,默认情况下 general_log 并没有开启:

MySQL怎么保证备份数据的一致性

我们可以通过修改配置文件 my.cnf(Linux)/my.ini(Windows),在 mysqld 下面增加或修改(如已存在配置项)general_log 的值为1,修改后重启 MySQL 服务即可生效。

也可以通过在 MySQL 终端执行 set global general_log = ON 来开启 general log,此方法可以不用重启 MySQL

MySQL怎么保证备份数据的一致性

开启之后,默认日志的目录是 mysql 的 data 目录,文件名默认为 主机名.log

接下来,我们先来执行一个不带 -–single-transaction 参数的备份,如下:

mysqldump -h localhost -uroot -p123 test08 > test08.sql

MySQL怎么保证备份数据的一致性

大家注意默认的 general_log 的位置。

接下来我们再来加上 -–single-transaction 参数看看:

mysqldump -h localhost -uroot -p123 --single-transaction test08 > test08.sql

MySQL怎么保证备份数据的一致性

大家看我蓝色选中的部分,可以看到,确实先开启了事务,然后才开始备份的,对比不加 -–single-transaction 参数的日志,多了开启事务这一部分。

以上就是MySQL怎么保证备份数据的一致性的详细内容,更多请关注其它相关文章!


# 解决这个问题  # 遂宁网站建设服务商  # 兴县网站seo优化排名  # 六安seo网站优化  # 森淼seo  # 在哪个权重高的网站推广  # 上饶网站建设推荐  # 企业网站建设招标  # 抖音seo优化阿信  # 四川企业网站设计推广  # 淮安网站建设与推广方案  # MySQL  # 最容易  # 重启  # 也很  # 我们可以  # 这就是  # 就会  # 客户端  # 可以看到  # 镜像 


相关栏目: 【 Google疑问12 】 【 Facebook疑问10 】 【 优化推广96088 】 【 技术知识133117 】 【 IDC资讯59369 】 【 网络运营7196 】 【 IT资讯61894


相关推荐: Apple Music无故扣费引质疑  盲鳗善于分泌黏液猜猜主要用来做什么  Highcharts雷达图轴线交点数值标注指南  飞飞漫画漫画阅读官网_飞飞漫画漫画阅读官网进入阅读  《桃源记2》资源采集攻略  《偃武》甘宁技能详解  《崩坏:星穹铁道》3.6版本异相仲裁打法及配队推荐  汽水音乐车机版官网5.0 汽水音乐车机版5.0版本下载入口  Go语言反射机制下访问嵌入结构体中的被遮蔽方法  PHP中动态类名访问的类实例类型提示与静态分析实践  Highcharts雷达图径向轴数值标签实现教程  PPT页面尺寸怎么修改 PPT自定义幻灯片大小与方向设置【教程】  喜茶GO更换登录账号方法  J*aScript字符串_Unicode处理  深入理解Python对象引用与链表属性赋值  12306夜间购票失败? | 查看官方公布的暂停服务公告与应对方案  Python定时发送QQ消息  《密马》发布账号方法  在J*a中如何实现在线问答与评分系统_问答评分项目开发方法说明  圆通快递官网入口查询单号 手机版官方查询入口  b站如何剪辑视频_b站必剪app使用教程  PDF如何批量加注释_PDF多文件批注高亮操作教程  《万兴喵影》导出视频方法  酷狗音乐多音轨设置教程  CSS过渡如何实现按钮悬停效果_transition属性控制背景颜色变化  c++如何掌握指针的核心用法_c++指针入门到精通指南  键盘声音异常怎么回事_键盘异响怎么处理  高德地图怎么查看未来行程规划_高德地图未来行程规划查看方法  美发店速赢秘籍  抖音火山版如何进行提现  vivo浏览器怎么离线保存网页 vivo浏览器下载完整页面以便无网络时阅读  使用Python和NLTK从文本中高效提取名词的实用教程  知乎APP怎么查看自己被邀请的问题_知乎APP邀请回答记录查看与参与方法  网页版网易云音乐入口_网易云音乐在线官网登录  如何编写一个符合 composer 规范的 post-install-cmd 脚本?  优化 React onClick 事件处理:函数引用与箭头函数的对比  QQ网站入口直接登录 QQ官方正版登录页面  ao3入口镜像地址 ao3镜像入口可靠跳转  Google Drive API 认证:服务账户与OAuth 2.0的选择与实践  解决CSS布局中意外顶部空白问题的教程  win11如何运行chkdsk命令 Win11检查和修复磁盘逻辑错误教程【修复】  QQ网页版官方账号登录入口 QQ网页版网页版入口快速导航  如何解决Casbin日志与应用日志不统一的问题,使用casbin/psr3-bridge实现无缝集成  《东方航空》添加乘机人方法  汽水音乐车机版 汽水音乐车机版官方入口  VS Code的时间线(Timeline)视图:您的代码时光机  Python中深度嵌套字典与列表的数据提取与条件过滤指南  139邮箱登录入口官网 139邮箱登录入口官网网址  铁路12306官网登录入口 铁路12306在线购票官方平台  性能与资源监视器快捷打开 

 2023-05-30

了解您产品搜索量及市场趋势,制定营销计划

同行竞争及网站分析保障您的广告效果

点击免费数据支持

提交您的需求,1小时内享受我们的专业解答。

运城市盐湖区信雨科技有限公司


运城市盐湖区信雨科技有限公司

运城市盐湖区信雨科技有限公司是一家深耕海外推广领域十年的专业服务商,作为谷歌推广与Facebook广告全球合作伙伴,聚焦外贸企业出海痛点,以数字化营销为核心,提供一站式海外营销解决方案。公司凭借十年行业沉淀与平台官方资源加持,打破传统外贸获客壁垒,助力企业高效开拓全球市场,成为中小企业出海的可靠合作伙伴。

 8156699

 13765294890

 8156699@qq.com

Notice

We and selected third parties use cookies or similar technologies for technical purposes and, with your consent, for other purposes as specified in the cookie policy.
You can consent to the use of such technologies by closing this notice, by interacting with any link or button outside of this notice or by continuing to browse otherwise.