mysql在生产环境执行DDL的风险_如何使用GH-OST在线修改

GH-OST通过binlog同步与影子表实现无锁DDL,要求ROW格式、log_slave_updates=ON;启动前须验证binlog可访问、主键存在、max_allowed_packet足够;切表后需手动删旧表、清理残留连接并补全外键等对象。DDL直接执行会锁表,GH-OST能绕过这个限制MySQL 5.7 及以前版本对大多数 ALTER TABLE 操作仍采用"拷表"方式:新建临时表、逐行复制数据、重命名。期间原表会被加上 MDL_WRITE 锁(元数据锁),DML(INSERT/UPDATE/DELETE)会阻塞,线上服务可能超时或雪崩。GH-OST 的核心思路是"不锁原表",它通过模拟从库 IO 线程读取 binlog,解析出变更并实时同步到影子表;同时用触发器(或更推荐的 binlog 模式)捕获原表增量变更,确保影子表最终一致。整个过程原表始终可读写。关键前提:binlog_format=ROW 且 log_slave_updates=ON(即使单机也要开),否则 GH-OST 无法准确捕获变更。启动 GH-OST 前必须验证的三件事很多人跳过校验直接跑,结果中途失败、切表卡死、主从延迟飙升------问题往往出在启动前没确认清楚: 唱鸭 音乐创作全流程的AI自动作曲工具,集 AI 辅助作词、AI 自动作曲、编曲、混音于一体

相关推荐
小白考证进阶中6 小时前
Oracle OCP证书报考&考试全指南
数据库·oracle·oracle ocp·ocp认证·oracle认证·甲骨文认证·oracle ocp题库
星恒随风6 小时前
Python 基础语法详解(一):从表达式、变量到数据类型
开发语言·笔记·python·学习
888CC++6 小时前
java 并发编程
java·开发语言·python
Dxy12393102167 小时前
python缩放图片如何保证图片质量
python
Leon-Ning Liu7 小时前
【真实经验分享】 ORA-600 [qesmaGetTblSeg1]
数据库·oracle
与数据交流的路上7 小时前
MySQL 优化 -- 相关
数据库·mysql
ZHW_AI课题组7 小时前
腾讯云调用IP定位
人工智能·python·机器学习
Rooting++7 小时前
为什么mysql的表字段的collation会自动变
数据库·mysql
Wch1G0z8A7 小时前
Google 开源了啥,让 AI Agent 碰数据库不再是定时炸弹
数据库·人工智能·开源
zhaoshuzhaoshu7 小时前
Python文件操作详细解析带例子
python