mysql 5.6 在线DDL
发表于:2025-01-25 作者:千家信息网编辑
千家信息网最后更新 2025年01月25日,online ddl主要包括3个阶段,prepare阶段,ddl执行阶段,commit阶段,rebuild方式比no-rebuild方式实质多了一个ddl执行阶段,prepare阶段和commit阶段
千家信息网最后更新 2025年01月25日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安全错误
数据库的锁怎样保障安全
文件管理和数据库的区别
WINDOWS美化软件开发
女生学计算机网络技术能当黑客吗
软件开发人.月报价模板
台州金融软件开发公司吗
网络安全法立法的总体思想
有哪些贸易数据库
软件开发培训技术培训
为什么手机联通无服务器
inux服务器开源
山东综合软件开发服务价格
全国职工技能大赛网络安全
软件开发 软件设计
数据库都需要什么基础
拳头服务器怎样登陆
云南荣顺网络技术有限公司
微信怎么删除合元软件开发
小学生写关于网络安全的提案
服务器如何查看磁盘io
数据库提高效率
园区网网络安全比例
即时通讯软件开发电话
德惠有名的网络技术诚信服务
国家应该管控游戏软件开发
软件开发流程瀑布
徐汇区人工智能应用软件开发售价
网络安全认识从哪几方面
无限流量用什么服务器
厦门流量变现软件开发
tmodloader服务器核心