stmt如何获取完整sql_第17问:如何评估 alter table 的进度?

0ea101426e0f8cbe468014fc113dc12b.png

问题

我们执行 alter table 语句后,经常面临“跑又跑不完,杀又不敢杀”的窘境。

如果能评估 alter table 的进度就幸福多了。

实验

MySQL官方已经给出了文档:https://dev.mysql.com/doc/refman/5.7/en/monitor-alter-table-performance-schema.html,我们来实践一下:

先建个数据库:

552050f13ba49966e9e348727b1f2b22.png

我们设置了一些跟 performance_schema 相关的参数,开启了查看进度必要的功能。

还是按照之前实验 11的技巧,快速造一些数据:

19006826a0eef3be10c4aa8855e03d5c.png

重复执行 insert,让表中有足够数据:

882d6158c72e9e9962d6eb6ec3b1b7cf.png

我们来跑一个alter table:

44a5035f62afd4e3802cff305339c74a.png

在另一个 session 中,执行 SQL 查看进度:

ca7aa663f5bac0d71a2728ea72a5d99c.png

看起来 SQL 比较复杂,我们先来看看效果:

这里列出了正在执行的 DDL SQL,进度评估,当前运行语句的时间,和估算的剩余时间。

不断获取进度:

29f77c2d52599f6bd4e6eb23e7361167.png

55e5d4185f44a67290714691f179bb57.png

3b078aa6937b0c6ae55d643f15e419cc.png

12e4e749d156e4235011df006166b213.png

4601c82a0298c508f4047327e38ad3ae.png

4056391e468dccde5cdbb42f80ac258f.png

fd442f8aae7a84e4fc5f70fa4a5b6199.png

可以看到,估算的剩余时间不是完全精确,在整个过程中,进度在不停被评估。不过这种精确度对于我们也足够用了。

我们来看看评估的主要原理:

fd3b85ed1d573f974b0b4dda99e72c81.png

在这张表里,MySQL 提供了如下信息:

  • DDL 语句运行的当前阶段
  • 当前阶段的开始时间和结束时间,当前阶段未结束时,结束时间为当前时间
  • 父事件 ID,语句运行的各个阶段,会具有相同的父事件 ID
  • 工作量评估,MySQL 将 DDL 的运行过程拆成一个一个任务包,这里提供了已经完成的任务包数量和估算的任务包总数量,两者的比值即为当前进度

(注意:这里的时间是当前阶段的时间,而工作量评估是整个语句的工作量)这下我们使用的评估 SQL 就不难看懂了:

692adbe9f2c8adaf83822af61c0cf1a4.png

附上评估语句的文字版:

select
    stmt.SQL_TEXT as sql_text,
    concat(WORK_COMPLETED, '/' , WORK_ESTIMATED) as progress,
    (stage.TIMER_END - stmt.TIMER_START) / 1e12 as current_seconds,
    (stage.TIMER_END - stmt.TIMER_START) / 1e12 * (WORK_ESTIMATED-WORK_COMPLETED) / WORK_COMPLETED as remaining_seconds
    from events_stages_current stage, events_statements_current stmt
    where stage.THREAD_ID = stmt.THREAD_ID
      and stage.NESTING_EVENT_ID = stmt.EVENT_ID;
小贴士
肯定会有同学问:那开启 performance_schema 会不会影响性能呢?
答:在美好的生活面前,不要因噎废食,多用 1% 的 CPU,不会耗太多电的。

关于 MySQL 的技术内容,你们还有什么想知道的吗?赶紧留言告诉小编吧!

77fb7faeb2bb8fd399c401b5fba69045.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器学习模型机器
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值