开发者社区 > 云存储 > 对象存储OSS > 正文

使用oss并发下载文件时数据内容被损坏

背景

在使用多线程并发下载oss文件时,偶尔会出现多个线程下载同一文件,导致文件损坏。
例如:线程A和线程B同时下载文件txt到本地的/tmp/test.txt中,下载完成后文件被损坏,无法打开。

private void consumer() {
    for (int i = 0; i < 15; i++) {
        Thread consumer = new Thread(String.format("SstLoadTask-MainConsumer-Thread-%s", i)) {
            @Override
            public void run() {
                DownloadFileRequest request = new DownloadFileRequest("bucket", "test.txt");
                request.setDownloadFile("/tmp/test.txt");
                OSS oss = new OSSClientBuilder().build();
                oss.downloadFile(request);
            }
        };
        consumer.start();
    }
}

问题

各位大佬,请问上面操作导致文件损坏的原因是什么?是因为oss分片下载的时候把数据损坏了吗?

展开
收起
搬砖工程师三 2023-10-25 16:08:57 57 0
0 条回答
写回答
取消 提交回答

相关产品

  • 对象存储
  • 热门讨论

    热门文章

    相关电子书

    更多
    OSS运维进阶实战手册 立即下载
    《OSS运维基础实战手册》 立即下载
    OSS运维基础实战手册 立即下载