mysqldump输出方式和进度报告

mysqldump在导出数据的过程中是“沉默”的,为了显示导出进度,给它加一个小patch显示进度。感谢 @宁青_ 的需求。

一、mysqldump输出方式

这个patch比较简单,先说一下相关的一个背景:mysqldump的输出方式。
1、  默认方式 stdout
2、  指定文件
-r target_file 可以指定导出的内容写入文件target_file中
3、–tab=path
在path目录下,对每个表生成两个文件,如表a生成a.sql和a.txt,分别存储表的定义和表的内容。

注意在指定—tab参数时,使用的是select into outfile …因此对指定的用户权限要求更高。

二、进度报告patch

增加参数 --progress-report 后,执行效果如下:

如图会依次显示每个表的导出进度。 可执行文件下载

 进度报告是否显示与dump时指定的输出方式有关:

1、不指定-r参数则无效。由于进度报告需要输出在stdout,因此若无-r参数,则—report-gress参数无效(否则显示混乱,而且会破坏默认输出)

  考虑到有程序会通过管道将输出直接导入到别的系统,将进度报告改为stderr,因此此限制取消

   

2、 指定—tab时无效。 –tab时使用into outfile无法获取执行进度。

猜你喜欢

转载自dinglin.iteye.com/blog/1759457