昨天维护的编译软件出了一个奇怪的问题,功能大概是这样的: java
一、下载资源和代码; linux
二、编译; windows
三、将须要打包的文件复制到临时目录打包。 递归
后来因为新需求,修改了一下功能,在复制到临时目录以前还有回去一些资源到临时目录: 资源
2.五、下载三方资源到临时目录。 编译
增长此功能后错误就出现了,复制的临时目录的结构全乱了,好比: 打包
java/bin应复制到temp/bin,结果去错误的复制到了temp/bin/bin。 软件
看到此问题我觉得是2.5步骤中下载的资源包目录有问题,将功能运行到2.5步中止查看目录无问题,保留第3步把2.5删除也无问题,惟独这些一块儿运行就有问题,并且windows系统下没问题,Linux却有问题。 下载
后来一位前辈想到了问题的缘由,linux系统下面调用了cp命令来复制文件和文件夹,问题就出在这里。 di
调用的命令 cp -arf srcdir destdir
-a是要复制连接文件,有些生僻,-r递归-f强制较常见。
从srcdir到destdir有讲究。举例子来讲:
cp -arf java/bin temp/bin 有两种状况的复制:
a.复制前 若temp/bin不存在,则将java/bin直接复制到temp,即temp/bin就是java/bin;
b.复制前 若temp/bin存在,则将java/bin复制到temp/bin/中,即temp/bin/bin才是java/bin。
以前没有2.5步temp下的bin不存在因此不会有问题,加入2.5步使得bin目录存在了因此致使复制出错。
解决方式是这样复制
cp -arf java/bin temp/
这样不论怎样都会正确,注意temp后必定要加/。
另外,windows下使用的是xcopy命令,不会有这样的问题。