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参数无效(否则显示混乱,而且会破坏默认输出)
2、 指定—tab时无效。 -tab时使用into outfile无法获取执行进度。
觉得文章有用?立即:
和朋友一起 共学习 共进步!
mysqldump 没有–progress-report选项,man mysqldump中没有,如何实现呢?
# mysqldump -uxxx -pxxx –default-character-set=utf8 –single-transaction –progress-report gold | gzip > backup_gold.sql.gz
mysqldump: unknown option ‘–progress-report’
[root@idc040vm020 ~]# mysql -V
mysql Ver 14.14 Distrib 5.5.29, for Linux (x86_64) using EditLine wrapper
[root@idc040vm020 ~]#