mysql 5.6 在线DDL
发表于:2025-11-06 作者:千家信息网编辑
千家信息网最后更新 2025年11月06日,online ddl主要包括3个阶段,prepare阶段,ddl执行阶段,commit阶段,rebuild方式比no-rebuild方式实质多了一个ddl执行阶段,prepare阶段和commit阶段
千家信息网最后更新 2025年11月06日mysql 5.6 在线DDL
online ddl主要包括3个阶段,prepare阶段,ddl执行阶段,commit阶段,rebuild方式比no-rebuild方式实质多了一个ddl执行阶段,prepare阶段和commit阶段类似。下面将主要介绍ddl执行过程中三个阶段的流程。
Prepare阶段:
创建新的临时frm文件(与InnoDB无关)
持有EXCLUSIVE-MDL锁,禁止读写
根据alter类型,确定执行方式(copy,online-rebuild,online-norebuild)
假如是Add Index,则选择online-norebuild即INPLACE方式更新数据字典的内存对象
分配row_log对象记录增量(仅rebuild类型需要)
生成新的临时ibd文件(仅rebuild类型需要)
ddl执行阶段:
降级EXCLUSIVE-MDL锁,允许读写
扫描old_table的聚集索引每一条记录rec
遍历新表的聚集索引和二级索引,逐一处理
根据rec构造对应的索引项
将构造索引项插入sort_buffer块排序
将sort_buffer块更新到新的索引上
记录ddl执行过程中产生的增量(仅rebuild类型需要)
重放row_log中的操作到新索引上(no-rebuild数据是在原表上更新的)
重放row_log间产生dml操作append到row_log最后一个Block
commit阶段:
当前Block为row_log最后一个时,禁止读写,升级到EXCLUSIVE-MDL锁
重做row_log中最后一部分增量
更新innodb的数据字典表
提交事务(刷事务的redo日志)
修改统计信息
rename临时idb文件,frm文件
变更完成
阶段
索引
文件
方式
类型
更新
增量
数据
事务
字典
对象
过程
三个
信息
内存
实质
日志
是在
流程
中产
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
程序设计与软件开发
互联网科技与企业
plsql不同服务器数据传输
第一台云服务器视频
软件开发维护期限
福建三文网络技术有限公司
深圳工控软件开发哪家实惠
10万条目数据库
软件开发师 系统架构师
届国家网络安全周主题班会
我的世界服务器公会管理
win7怎么制作服务器
数据库需求分析怎么画数据流程图
mysqul数据库下载
政府单位 网络安全 重要性
数据库长连接优化
人工智能网络安全与技术就业
企业网络安全检测工具
网络技术与信息安全专业就业
战地5开服务器刷皮封号吗
程序设计与软件开发
分布式redis数据库解题技巧
佛山智能软件开发
服务器能放几台主机
科东网络安全监控装置配置
观看网络安全宣传周心得体会
绍兴仓库管理软件开发
仓库管理数据库
k3服务器中间层配置
数据库系统实战案例