今天客户打电话来说我们的系统备份的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、前提是让客户部署时,别将项目部署在含有空格的文件夹下面。
记录下问题的解决方法以供参考。
热门文章
- 宠物粮食加工厂设备有哪些种类的呢 宠物粮食加工厂设备有哪些种类的呢图片
- 养猫的人容易得什么寄生虫病(养猫会得什么寄生虫)
- 广州猫猫领养园电话(广州猫咪领养中心在哪)
- 宠物粮食生产厂家排名(宠物粮食公司)
- 宠物店狗粮多少钱一斤(宠物店狗粮一般多少钱一斤)
- 3月2日→19.8M/S|2025年最新免费节点Clash/Shadowrocket/SSR/V2ray订阅链接地址
- 济南哪里有免费领养宠物的地方呀(济南免费领养宠物狗)
- 宠物收购中心收购清远(宠物收购站)
- 1月22日→21.8M/S|2025年最新免费节点V2ray/Clash/Shadowrocket/SSR订阅链接地址
- 1月13日→19M/S|2025年最新免费节点SSR/Shadowrocket/V2ray/Clash订阅链接地址