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 后,执行效果如下:
如图会依次显示每个表的导出进度。 下载 mysqldump
进度报告是否显示与dump时指定的输出方式有关:
1、不指定-r参数则无效。由于进度报告需要输出在stdout,因此若无-r参数,则—report-gress参数无效(否则显示混乱,而且会破坏默认输出)
考虑到有程序会通过管道将输出直接导入到别的系统,将进度报告改为stderr,因此此限制取消
2、 指定—tab时无效。 –tab时使用into outfile无法获取执行进度。
转载请注明:爱开源 » mysqldump 输出方式和进度报告