怎么查看 mysqlbinlog 的解析进度

发布时间:2020-05-22 浏览次数:438

问题

mysqlbinlog 是将 binlog 解析成可读可执行的 SQL 的重要工具。

但解析体积较大的 binlog 时,如何查看 mysqlbinlog 的执行进度就变成了一个问题,mysqlbinlog 并未提供 –progress 这样的参数。

那要怎么查看 mysqlbinlog 的解析进度?


实验

我们在 实验 08 中介绍了如何生成随机数据。可以利用其中技巧,生成较大的 binlog,我们忽略这个过程。

从已有的 binlog 开始,bin.000002 大约有 1.1 个 G:

怎么查看 mysqlbinlog 的解析进度-爱可生


用 mysqlbinlog 解析该 binlog:

怎么查看 mysqlbinlog 的解析进度-爱可生


大概会执行 4.6 秒左右。大家仔细做实验时,可以将 binlog 放大一些,让执行实验更长一些。

我们在 mysqlbinlog 解析时,查看其文件句柄:

怎么查看 mysqlbinlog 的解析进度-爱可生


可以看到 mysqlbinlog 用句柄 3 读取 binlog。(我们暂时忽略句柄 4 指向的临时文件,其涉及到了行格式的解析过程,我们安排在以后的实验中慢慢介绍)

获取了 mysqlbinlog 处理文件句柄 3 的进度,就可以大概估算 mysqlbinlog 的整体进度:

怎么查看 mysqlbinlog 的解析进度-爱可生


可以看到 mysqlbinlog 此时的进度大概是 600M 左右,整体进度估算为 54%。


结论


我们无法让 mysqlbinlog 直接输出进度,于是通过观察 mysqlbinlog 对 binlog 的读取进度,估算mysqlbinlog 的整体处理进度。

mysqlbinlog 不是真的"流式"处理 binlog,所以本实验只能是估算,大家在实验时,会观察到 mysqlbinlog 读取了全部 binlog 后,会继续处理一点时间,才完成所有工作。

我们以后安排实验来研究 mysqlbinlog 是如何处理 binlog 的。

上一篇: 给大家介绍一下percona QAN

下一篇: MySQL里列非空与自增

产品试用 产品试用
400-820-6580 免费电话