Mysql Online DDL的使用详解


Posted in MySQL onMay 20, 2021

正文

Online DDL在MySQL 5.6才开始支持的,在5.5及之前版本,使用alter table/create index等命令进行表结构修改操作均会锁表,这在生产环境上明显是不可接受的。

在MySQL 5.7,Online DDL在性能和稳定性上不断得到优化,性能有显著优势,且对业务负载影响小,停写时间可控,相对pt-osc/gh-ost来说,无需安装第三方依赖包,同时支持Inplace算法的Online DDL,由于无需拷表,所需磁盘空间也更小。

先来看一个常见的DDL语句:

ALTER TABLE tbl_name ADD PRIMARY KEY (column), ALGORITHM=INPLACE, LOCK=NONE;

其中,LOCK描述了DDL期间运行的并发程度,ALGORITHM描述了DDL的实现方式

LOCK参数

  1. LOCK=NONE:允许并发的查询和DML操作
  2. LOCK=SHARED:允许并发的查询,但阻塞DML操作
  3. LOCK=DEFAULT: 由系统决定,允许尽可能多的并发性(并发查询、DML或两者)。如果省略LOCK子句相当于指定LOCK=DEFAULT
  4. LOCK=EXCLUSIVE:阻塞并发查询和DML操作。

ALGORITHM参数

  1. ALGORITHM=COPY:采用拷表方式进行表变更,与pt-osc/gh-ost类似;
  2. ALGORITHM=INPLACE:仅需要进行引擎层数据改动,不涉及Server层;

COPY TABLE流程

  1. 首先建立临时表,表结构为ALTAR TABLE更改后的结构
  2. 将原表中数据导入到临时表(server层创建临时表,会有显示的IBD文件)
  3. 删除原表
  4. 将临时表rename为原来的表名

同时这一过程中,为了保持数据的一致性,中间复制数据时(Copy Table)全程锁表只读,如果有写请求进来将无法提供服务,将导致连接数爆张。

IN-PLACE流程

  1. 建立一个临时文件,扫描原表主键的所有数据页
  2. 用数据页中原表记录生成B+树,存储到临时文件中(innodb_temp_data_file_path临时表空间下创建临时文件)
  3. 生成临时文件的过程中,将所有对原表的操作记在一个日志文件(rowlog)中
  4. 临时文件生成后,将日志文件中的操作应用到临时文件,得到一个辑数据上与原表相同
  5. 数据文件(日志文件记录和重放操作)
  6. 用临时文件替换原表数据文件

这一过程中,alter 语句在启动的时候获取MDL写锁,但是这个写锁在真正拷贝数据之前就退化成读锁,也就是说在最耗时的copy数据到临时文件的过程中,原表是可以进行dml操作的,仅仅会在最后的新旧表切换阶段加锁,这个rename的时间就非常快了。

允许并发DML的DDL操作

  • 创建/新增二级索引
  • 重命名二级索引
  • 删除二级索引
  • 改变索引类型(USING {BTREE | HASH})
  • 添加主键(expensive cost)
  • 删除主键并增加另一个(expensive cost)(ALTER TABLE tbl_name DROP PRIMARY KEY, ADD PRIMARY KEY (column), ALGORITHM=INPLACE, LOCK=NONE;)
  • 新增列 (expensive cost)
  • 删除列 (expensive cost)
  • 重命名列
  • 列重新排序 (expensive cost)
  • 改变列默认值
  • 删除列默认值
  • 改变列自增值
  • 设置列属性null/not null (expensive cost)
  • 修改枚举或集合列的定义
  • Change ROW_FORMAT
  • Change key block size

标记为expensive cost的操作虽然允许OnlineDDL,但本身对服务器IO,CPU都会造成较高负担,同时会导致复制阻塞,造成另一种形式的从库复制延迟,所以如果是大表,建议业务低峰期执行

不允许并发DML的DDL操作

  • 添加全文索引
  • 添加空间索引
  • 删除主键
  • 改变列数据类型
  • 添加自增列(新增列->变为自增列)
  • 变更表字符集
  • 修改数据类型长度
    • 特例:varchar字符长度从10变更到小于255 采用inplace方式不会锁表;从255变更到10会锁表;

以上就是Mysql Online DDL的使用详解的详细内容,更多关于Mysql Online DDL的使用的资料请关注三水点靠木其它相关文章!

MySQL 相关文章推荐
Navicat for MySQL的使用教程详解
May 27 MySQL
MySQL系列之十二 备份与恢复
Jul 02 MySQL
mysql脏页是什么
Jul 26 MySQL
SQL实现LeetCode(175.联合两表)
Aug 04 MySQL
一次MySQL启动导致的事故实战记录
Sep 15 MySQL
Mysql关于数据库是否应该使用外键约束详解说明
Oct 24 MySQL
mysql主从复制的实现步骤
Oct 24 MySQL
MYSQL 表的全面总结
Nov 11 MySQL
浅谈如何保证Mysql主从一致
Mar 13 MySQL
一次SQL如何查重及去重的实战记录
Mar 13 MySQL
mysql的Buffer Pool存储及原理
Apr 02 MySQL
MySQL详细讲解变量variables的用法
Jun 21 MySQL
MySQL 存储过程的优缺点分析
May 20 #MySQL
IDEA 链接Mysql数据库并执行查询操作的完整代码
MySQL 覆盖索引的优点
May 19 #MySQL
MySQL 视图(View)原理解析
超详细教你怎么升级Mysql的版本
详解mysql三值逻辑与NULL
MySQL时间盲注的五种延时方法实现
You might like
PHP的ASP防火墙
2006/10/09 PHP
php之Memcache学习笔记
2013/06/17 PHP
Centos6.5和Centos7 php环境搭建方法
2016/05/27 PHP
php 数组元素快速去重
2017/05/05 PHP
PHP PDOStatement::fetchColumn讲解
2019/01/31 PHP
javascript mouseover、mouseout停止事件冒泡的解决方案
2009/04/07 Javascript
parseInt parseFloat js字符串转换数字
2010/08/01 Javascript
JavaScript高级程序设计 DOM学习笔记
2011/09/10 Javascript
用js获取电脑信息(是使用与IE浏览器)
2013/01/15 Javascript
JS性能优化笔记搜索整理
2013/08/21 Javascript
引入JS文件IE6报语法错误或缺少对象问题的解决方法
2014/01/09 Javascript
Javascript保存网页为图片借助于html2canvas库实现
2014/09/05 Javascript
javascript实现树形菜单的方法
2015/07/17 Javascript
jqueryMobile使用示例分享
2016/01/12 Javascript
Javascript基础教程之比较null和undefined值
2016/05/16 Javascript
js中window.open的参数及注意注意事项
2016/07/06 Javascript
js定时器实例分享
2016/12/20 Javascript
AngularJS实现自定义指令及指令配置项的方法
2017/11/20 Javascript
SpringBoot+Vue 前后端合并部署的配置方法
2020/12/30 Vue.js
[01:17:47]TNC vs VGJ.S 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
Python通过matplotlib画双层饼图及环形图简单示例
2017/12/15 Python
Python数据结构之哈夫曼树定义与使用方法示例
2018/04/22 Python
django之静态文件 django 2.0 在网页中显示图片的例子
2019/07/28 Python
Django 5种类型Session使用方法解析
2020/04/29 Python
CSS3绘制六边形的简单实现
2016/08/25 HTML / CSS
BIBLOO捷克:购买女装、男装、童装、鞋和配件
2017/01/27 全球购物
具有防紫外线功能的高性能钓鱼服装:Hook&Tackle
2018/08/16 全球购物
英国时尚泳装品牌:Maru Swimwear
2019/10/06 全球购物
Oracle性能调优原则
2012/05/03 面试题
介绍一下EJB的体系结构
2012/08/01 面试题
生物医学工程专业学生求职信范文分享
2013/12/14 职场文书
现金出纳岗位职责
2014/03/15 职场文书
演讲主持词
2014/03/18 职场文书
新闻传播专业求职信
2014/07/22 职场文书
求职信:会计求职的写作技巧
2019/04/24 职场文书
原来实习报告是这样写的呀!
2019/07/03 职场文书