产生原因:目前开发中遇到的场景是这样的,我有一个方法a需要从公司
ftp服务器上取图片下来保存到一个临时目录。然后通过 amazonS3.putObject() 方法保存图片,保存完后从 本地的临时目录删掉。
由于文件名不是唯一,多线程的时候就会有问题,假如 x 线程 和 y 线程刚好都在操作同一个文件, x 线程存完后删除,y 线程存到一半就不行了 ,这时候就会报错 Data read has a different length than the expected,
可以理解为:amazon原本得知即将要存 1M 的数据,结果接收过来的数据只有 0.5M ,和实际大小不符合就会报错了
解决方案:
我这种情况是文件名重复导致(具体情况具体分析)。
文件名拼上时间搓或者uuid。
实际测试中多线程情况下使用java.util.UUID.randomUUID(); 会出现uuid重复,而使用 下面这段代码 的uuid不会重复
public static String randomUUID() {
ThreadLocalRandom random = ThreadLocalRandom.current();
return (new UUID(random.nextLong(), random.nextLong())).toString().replace("-", "");
}