Callable Future 实现多线程按照顺序上传文件

/**

* 异步上传 BiopsyFlow 中的所有视频和音频文件到暂存服务器

*/

private List<String> uploadBiopsyFlowFiles(BiopsyFlow biopsyFlow, SyncFile SyncFile) {

List<String> fileBase64List = syncFile.getFileBase64List();

if (CollectionUtils.isEmpty(syncFile.getFileBase64List())) {

log.info("没有文件需要上传");

return Collections.emptyList();

}

log.info("上传文件数量:{}", fileBase64List.size());

List<Callable<String>> tasks = new ArrayList<>();

for (String file : fileBase64List) {

Callable<String> task = () -> {

log.debug("上传线程:{}", Thread.currentThread().getName());

try {

return fileDealUtils.uploadTxFile(file, biopsyFlow.getTransId());

} catch (Exception e) {

log.error("文件上传失败, 异常={}", e.getMessage());

return null;

}

};

tasks.add(task);

}

// 使用公共线程池提交任务

List<Future<String>> futures = new ArrayList<>();

try {

for (Callable<String> task : tasks) {

Future<String> future = pullVideoTaskExecutor.submit(task);

futures.add(future);

}

// 按顺序获取结果

List<String> fileIds = new ArrayList<>();

for (Future<String> future : futures) {

try {

String fileId = future.get();

if (fileId != null) {

fileIds.add(fileId);

} else {

log.error("文件上传失败: 返回的文件ID为空");

return Collections.emptyList();

}

} catch (Exception e) {

log.error("文件上传失败: 异常={}", e.getMessage());

return Collections.emptyList();

}

}

// // TODO 测试下载,上线之前删除

// for (String fileId : fileIds) {

// String base64 = fileDealUtils.testDownMp4(fileId);

// log.info("下载的文件id:{}, 对应下载的视频base64:{}", fileId,base64.substring(0,100));

// }

return fileIds;

} catch (Exception e) {

log.error("任务执行过程中发生异常", e);

return Collections.emptyList();

}

}

相关推荐
异常君2 分钟前
FST 在 Elasticsearch 中的核心应用与性能优化实践
java·elasticsearch·性能优化
周某某~4 分钟前
六.原型模式
java·设计模式·原型模式
异常君7 分钟前
通过 Elasticsearch 实现分布式事务的可靠方案
java·分布式·elasticsearch
小安同学iter23 分钟前
JUC并发编程(四)常见模式
java·开发语言
不再幻想,脚踏实地35 分钟前
Linux简单的操作
java·linux·运维·服务器
dayceng39 分钟前
一则复杂 SQL 改写后有感
java·数据库·mysql
周某某~1 小时前
五.建造者模式
java·设计模式·建造者模式
YuTaoShao1 小时前
Java八股文——Spring「SpringMVC 篇」
java·开发语言·spring
罗迪尼亚的熔岩1 小时前
在C# 中使用建造者模式
java·c#·建造者模式
vortex51 小时前
Yakit 热加载入门学习指南
java·服务器·前端