尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

mysql的 order by是怎么工作的?redo-log和binlog为什么采用双确认机制?

mysql的 order by是怎么工作的?redo-log和binlog为什么采用双确认机制?
📅 发布时间:2026/6/21 16:49:15

前言

一、order by 是怎么工作的?
二、redo-log和binlog为什么采用双确认机制
一、完整正常事务提交流程(主库)
各个节点宕机会怎么样?

  1. redo log prepare 之前宕机
  2. redo log 刷盘后宕机 没写binlog
  3. binlog刷盘成功,但是redo log 未commit就宕机了
  4. commit之后宕机
    加入主从复制后的完整流程(非常重要)
    主库已提交,但binlog未同步到从库
    从库执行 relay log 中途宕机
    把所有角色放在一张总览图(终极版)

mysql的 order by是怎么工作的?redo-log和binlog为什么采用双确认机制?

  • 前言
    • 一、order by 是怎么工作的?
    • 二、redo-log和binlog为什么采用双确认机制
      • 一、完整正常事务提交流程(主库)
      • 各个节点宕机会怎么样?
        • 1. redo log prepare 之前宕机
        • 2. redo log 刷盘后宕机 没写binlog
        • 3. binlog刷盘成功,但是redo log 未commit就宕机了
        • 4. commit之后宕机
      • 加入主从复制后的完整流程(非常重要)
        • 主库已提交,但binlog未同步到从库
        • 从库执行 relay log 中途宕机
      • 把所有角色放在一张总览图(终极版)

一、order by 是怎么工作的?

order by排序:通过索引获取所有符合条件的数据,然后放到sort_buff中进行排序。

如果需要查询的字段太长,可以通过配置项配置大小边界。

那么就会先获取排序字段和主键字段 然后sort_buff中排序,然后再去查表 获取完整结果。优化的方式可以通过在排序字段上建立索引(索引是有序的)来减少排序,通过建立覆盖索引,来减少回表

二、redo-log和binlog为什么采用双确认机制

为了保证事务的原子性+崩溃后恢复后的一致性,避免数据和日志的不一致性。

双确认机制,只有当两个日志都写入成功之后,事物才会真正的提交。

一、完整正常事务提交流程(主库)

┌────────────────────┐ │ 客户端发送 SQL │ └─────────┬──────────┘ │ ▼ ┌──────────────────────────┐ │InnoDB执行 SQL(改内存) │ │BufferPool│ └─────────┬────────────────┘ │ ▼ ┌──────────────────────────────────┐ │ 生成 redo log(PREPARE) │ │ redo log buffer │ └─────────┬────────────────────────┘ │ ▼ ┌──────────────────────────────────┐ │ redo log 刷盘(fsync) ✅ │ │ 【阶段一:Prepare】 │ └─────────┬────────────────────────┘ │ ▼ ┌──────────────────────────────────┐ │ 生成 binlog(事务事件) │ │ binlog cache │ └─────────┬────────────────────────┘ │ ▼ ┌──────────────────────────────────┐ │ binlog 刷盘(fsync) ✅ │ │ 【binlog 持久化】 │ └─────────┬────────────────────────┘ │ ▼ ┌──────────────────────────────────┐ │ redo log 写 COMMIT+刷盘 ✅ │ │ 【阶段二:Commit】 │ └─────────┬────────────────────────┘ │ ▼ ┌────────────────────┐ │ 事务提交成功返回 OK │ └────────────────────┘

刷盘:是指的从内存写入磁盘的操作,图中第一次 redo log 刷盘(fsync)是把redo log文件写到磁盘。刷盘的主要目的是防止崩溃后数据丢失。

当阶段二 Commit后,返回事物提交成功的同时,会异步把数据写入到.ibd文件中。

各个节点宕机会怎么样?

1. redo log prepare 之前宕机

事物没有开始 直接丢弃

2. redo log 刷盘后宕机 没写binlog

恢复流程:

扫描 redo log >发现PREPARE > 检查 binlog 不存在 >回滚事物

3. binlog刷盘成功,但是redo log 未commit就宕机了

扫描 redo log >发现PREPARE > 检查 binlog 存在 >补写redo log commit > 事物成功

4. commit之后宕机

扫描redo log > 发现commit 直接恢复

加入主从复制后的完整流程(非常重要)

Slave SQL Thread ↓ 读取 relay log ↓ 执行 SQL / 行事件 ↓ 生成 redo log ↓ redo log 刷盘 ↓ 数据落盘
主库已提交,但binlog未同步到从库

这是主从延迟,不是数据错误

从库执行 relay log 中途宕机

relay log 在
redo log 未 commit

恢复:

  • 从库根据 redo log 回滚/重做
  • 再继续执行 relay log

把所有角色放在一张总览图(终极版)

Client │ ▼ Master InnoDB │ redo log (prepare → commit) │ ▼ Master binlog ───────► Slave IO Thread │ ▼ relay log │ ▼ Slave SQL Thread │ ▼ Slave redo log │ ▼ Slave 数据文件

相关新闻

  • PaddlePaddle镜像中的模型解释性工具SHAP集成方法
  • UVC 红外相机初始化流程 setup包解析
  • 零基础搭建ESP32开发环境(Arduino IDE)

最新新闻

  • 购物卡回收平台哪个靠谱?我拿亲身经历跟你聊聊 - 京顺回收
  • 新手入门!名家字画收藏核心常识,避开90%收藏误区 - 深鉴新闻
  • cf982F
  • 2026年商用九倍鲜增鲜粉选购全攻略:主流产品测评与场景适配指南 - 麻辣烫酱料
  • NXP FXLS8962AF传感器寄存器配置实战:低功耗与事件驱动设计
  • 2026玻璃绝缘子技术解析与河北合规厂家选型参考-河北趋鹰电力 - 起跑123

日新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

周新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号