【发布时间】:2021-10-18 02:47:52
【问题描述】:
我使用的是 quarkus 版本2.3.0.Final。
我在Controller 层中有一个休息端点:
@POST
@Path("/upload")
@Produces(MediaType.APPLICATION_JSON)
@Consumes(MediaType.MULTIPART_FORM_DATA)
public Uni<Response> uploadFile(@MultipartForm FormData formData) {
return documentService.uploadFile(formData).onItem()
.transform(value -> Response.status(200)
.entity(value)
.build());
}
在service 层中的代码
public Uni<?> uploadFile(@NonNull FormData formData) throws Exception {
// Call to graphQl client using blocking process - the problem occurs here,
RevisionResponse revisionResponse = entityRepository.createRevision(formData);
// Do upload to s3 using s3 Async
return Uni.createFrom()
.future(
storageProviderFactory.getDefaultStorageProvider().upload(formData)))
.map(storageUploadResponse -> DocumentResponse.builder()
.id(revisionResponse.getId())
.entityMasterId(revisionResponse.getEntityMasterId())
.type(revisionResponse.getType())
.path(formData.getFilePath())
.description(formData.getDescription())
.build());
}
这是我使用的依赖项:
<dependency>
<groupId>io.quarkus</groupId>
<artifactId>quarkus-smallrye-graphql-client</artifactId>
</dependency>
<dependency>
<groupId>io.quarkus</groupId>
<artifactId>quarkus-resteasy-reactive</artifactId>
</dependency>
<dependency>
<groupId>io.quarkus</groupId>
<artifactId>quarkus-resteasy-reactive-jsonb</artifactId>
</dependency>
当我运行这个函数时,它被entityRepository.createRevision(formData) 阻塞(控制台显示了graphql请求日志,但实际上,请求甚至没有到达目标graphql端点)
但是,如果我在controller 层中添加注释@Blocking,一切都会按预期工作。
我也尝试使用Uni 响应Uni<RevisionResponse> revisionResponse = entityRepository.createRevision(formData);,但发生了同样的错误。
有人遇到这些问题吗,我是不是为非阻塞处理配置了错误?
谢谢。
【问题讨论】:
标签: java resteasy quarkus reactive graphql-java