MySQL数据库逻辑备份工具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参数无效(否则显示混乱,而且会破坏默认输出)

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

觉得文章有用?立即: 和朋友一起 共学习 共进步!

猜您喜欢

2 thoughts on “MySQL数据库逻辑备份工具mysqldump的输出方式和进度报告功能增加与改进

  1. 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 ~]#

发表评论

电子邮件地址不会被公开。 必填项已用 * 标注

*

您可以使用这些 HTML 标签和属性: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>