Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 6981|回复: 0

解决JAVA调用mysqldump备份数据库时文件为空的问题

[复制链接]
  • TA的每日心情
    奋斗
    昨天 14:49
  • 签到天数: 775 天

    [LV.10]以坛为家III

    2045

    主题

    2103

    帖子

    71万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    714292
    发表于 2021-4-15 12:35:35 | 显示全部楼层 |阅读模式

    今天客户打电话来说我们的系统备份的sql文件为空文件。

    这让我很凌乱,我们测试过滴,执行很成功嘛。

    可客户使用的时候确实是备份失败嘛 ,这是事实。

     

    我东测试西测试,在本机咋滴还是没出现这样的问题;

    没办法装了个虚拟机,安装了和客户一样的操作系统 ,并且按照客户安装步骤进行部署。

    结果,神奇事情出现了,所备份的数据库文件确实是空的,最后是东找西找,又是百度又是谷歌的,还是没有解决。

    后来我一想,mysql的安装路径不一样,我都喜欢把软件工具都安装在C盘以外,自定义的安装路径,而客户是安装在默认的Program Files下面,

    而文件夹有空格的名称的经常会致使一些莫名其妙的问题出现。

    想到就做,我将mysql bin目录下的mysqldump复制放到c盘,并且把系统语句改为

    Runtime rt = Runtime.getRuntime();

    rt.exec("cmd /c c:\\mysqldump -hlocalhost -uroot -p123456 --opt databaseName>d:\\bk.sql");

    居然成功了,文件不再是0KB的空文件。自此,问题解决。

     

    罪魁祸首是Program Files文件夹的空字符串,不知道当初微软为啥要在中间加个空格。

     

    我项目的解决方案就是:

    1、将mysqldump.exe复制放到我的项目文件夹下

    2、执行备份时,先得到项目部署路径,然后执行 

    Runtime rt = Runtime.getRuntime();

    String path = 获取mysqldump所在路径。 

    rt.exec("cmd /c "+path+"\\mysqldump -hlocalhost -uroot -p123456 --opt databaseName>d:\\bk.sql"); 

    3、前提是让客户部署时,别将项目部署在含有空格的文件夹下面。

     

    记录下问题的解决方法以供参考。 

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-8-15 07:58 , Processed in 0.058232 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表