MySQL version:8.0.13
MySQL workbench :8.0.13
使用Export Data时报:Could not get mysqldump version,具体如下:
首先,通过 Help -> Locate Log Files 找到 workbench 的日志文件所在位置 ~/.mysql/workbench/log ,查看 wb.log 文件中的内容,看到下面一句:
22:22:40 [ERR][wb_admin_export.py:get_mysqldump_version:117]: Could not parse version number from mysqldump:
mysqldump Ver 8.0.13 for Linux on x86_64 (MySQL Community Server - GPL)
估计应该是解析版本时发生错误导致了错误提示,顺藤摸瓜,查到一个靠谱的说是wb_admin_control.py中的正则表达式有错误导致的,可那是6.3版本的,在8.0.13的该文件中不存在类似代码,故将当前目录设定为 /usr/lib/mysql-workbench/modules/ ,然后使用 grep -r parse ./ 命令查找所有包含parse的所有文件。查到的结果中有如下一段内容:
./wb_admin_export.py: log_error("Could not parse version number from %s:\n%s"%(path, output))
这部分代码与wb.log中的内容相符,故检查 wb_admin_export.py 文件。发现其中一段代码如下:
def get_mysqldump_version():
path = get_path_to_mysqldump()
if not path:
log_error("mysqldump command was not found, please install it or configure it in Edit -> Preferences -> MySQL")
return None
output = StringIO.StringIO()
rc = local_run_cmd('"%s" --version' % path, output_handler=output.write)
output = output.getvalue()
if rc or not output:
log_error("Error retrieving version from %s:\n%s (exit %s)"%(path, output, rc))
return None
s = re.match(".*Distrib ([\d.a-z]+).*", output)
if not s:
log_error("Could not parse version number from %s:\n%s"%(path, output))
return None
version_group = s.groups()[0]
major, minor, revision = [int(i) for i in version_group.split(".")[:3]]
return Version(major, minor, revision)
其中, s = re.match(".*Distrib ([\d.a-z]+).*", output) 代码应该是用正则表达式提取版本号,使用mysqldump --versiion命令,查看dump版本号:
root@ONE:/usr/lib/mysql-workbench/modules$ mysqldump --version
mysqldump Ver 8.0.13 for Linux on x86_64 (MySQL Community Server - GPL)
可以看出版本号内容与之前的正则表达式不匹配,修正正则表达式如下:
s = re.match(".*mysqldump Ver ([\d.]+).*", output)
修正保存后,重启workbench,一切都好了。