如何使用WebClient执行零拷贝上载和下载?

时间:2017-10-14 01:37:14

标签: java spring-webflux

您可以使用org.springframework.web.reactive.function.client.WebClient使用Spring 5 WebFlux执行零拷贝上传和下载吗?

1 个答案:

答案 0 :(得分:4)

您说得对,从基于文件的Resource发布数据时,现在支持零拷贝。

所以以下看起来是正确的:

client.post()
      .body(BodyInserters.fromResource(new FileSystemResource(new File("file.txt"))));

现在对于阅读部分,Spring Framework中现在不支持零拷贝;你可以在jira.spring.io上创建一个增强问题。

您的代码示例应如下所示:

Flux<DataBuffer> incoming = client.post()
      .retrieve().bodyToFlux(DataBuffer.class);
Mono<Void> writeOperation = DataBufferUtils.write(incoming, channel)
      .map(DataBufferUtils::release)
      .then();
// subscribe to the returned value, which will complete when writing is done

不幸的是,将数据读取到DataBuffer将不会进行零拷贝,因为数据将被复制到内存中。我认为阅读方面不支持零拷贝,因此这可能是https://jira.spring.io上的增强请求。