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 相关文章推荐
MySQL之DML语言
Apr 05 MySQL
MySQL安装后默认自带数据库的作用详解
Apr 27 MySQL
解决MySQL存储时间出现不一致的问题
Apr 28 MySQL
正确使用MySQL update语句
May 26 MySQL
MYSQL主从数据库同步备份配置的方法
May 26 MySQL
MySQL 8.0 Online DDL快速加列的相关总结
Jun 02 MySQL
MYSQL 无法识别中文的永久解决方法
Jun 03 MySQL
安装配置mysql及Navicat prenium的详细流程
Jun 10 MySQL
Mysql8.0递归查询的简单用法示例
Aug 04 MySQL
MySQL面试题讲解之如何设置Hash索引
Nov 01 MySQL
MySQL RC事务隔离的实现
Mar 31 MySQL
MySQL中IO问题的深入分析与优化
Apr 02 MySQL
MySQL 存储过程的优缺点分析
May 20 #MySQL
IDEA 链接Mysql数据库并执行查询操作的完整代码
MySQL 覆盖索引的优点
May 19 #MySQL
MySQL 视图(View)原理解析
超详细教你怎么升级Mysql的版本
详解mysql三值逻辑与NULL
MySQL时间盲注的五种延时方法实现
You might like
在PHP中利用XML技术构造远程服务(上)
2006/10/09 PHP
PHP学习之PHP运算符
2006/10/09 PHP
ThinkPHP3.1新特性之对分组支持的改进与完善概述
2014/06/19 PHP
PHP扩展CURL的用法详解
2014/06/20 PHP
CodeIgniter集成smarty的方法详解
2016/05/26 PHP
Web跨浏览器进程通信(Web跨域)
2013/04/17 Javascript
jQuery 遍历- 关于closest() 的方法介绍以及与parents()的方法区别分析
2013/04/26 Javascript
js中document.write使用过程中的一点疑问解答
2014/03/20 Javascript
js 获取元素下面所有li的两种方法
2014/04/14 Javascript
jquery鼠标放上去显示悬浮层即弹出定位的div层
2014/04/25 Javascript
jQuery实现瀑布流的取巧做法分享
2015/01/12 Javascript
深入理解JavaScript系列(28):设计模式之工厂模式详解
2015/03/03 Javascript
通过点击jqgrid表格弹出需要的表格数据
2015/12/02 Javascript
浅析Javascript匿名函数与自执行函数
2016/02/06 Javascript
基于jQuery实现表格的排序
2016/12/02 Javascript
通过修改360抢票的刷新频率和突破8车次限制实现方法
2017/01/04 Javascript
关于jquery form表单序列化的注意事项详解
2017/08/01 jQuery
JS库之Three.js 简易入门教程(详解之一)
2017/09/13 Javascript
JavaScript实现随机数生成器(去重)
2017/10/13 Javascript
JavaScript比较同一天的时间大小实例代码
2018/02/09 Javascript
React中如何引入Angular组件详解
2018/08/09 Javascript
移动端 Vue+Vant 的Uploader 实现上传、压缩、旋转图片功能
2019/06/10 Javascript
layui 对弹窗 form表单赋值的实现方法
2019/09/04 Javascript
教你如何用Node实现API的转发(某音乐)
2019/09/20 Javascript
原生javascript实现类似vue的数据绑定功能示例【观察者模式】
2020/02/24 Javascript
Python3爬虫学习之MySQL数据库存储爬取的信息详解
2018/12/12 Python
对python操作kafka写入json数据的简单demo分享
2018/12/27 Python
PyQt5 实现给窗口设置背景图片的方法
2019/06/13 Python
基于Python批量生成指定尺寸缩略图代码实例
2019/11/20 Python
关于django python manage.py startapp 应用名出错异常原因解析
2020/12/15 Python
python实现经典排序算法的示例代码
2021/02/07 Python
美国本地交易和折扣网站:LocalFlavor.com
2017/10/26 全球购物
汽车专业毕业生自荐信
2013/11/03 职场文书
劳动实践课感言
2014/02/01 职场文书
银行委托书范本
2014/04/04 职场文书
文员岗位职责范本
2015/04/16 职场文书