如何使用 Graphql SPQR 库实现 GraphQL 的订阅功能?
1 回答
一般而言,您只需使用注释方法@GraphQLSubscription
并确保该方法返回一个org.reactivestreams.Publisher
. 例如
@GraphQLSubscription
public Publisher<Issue> issueStatusChanged(String code) {
return ...;
}
但在实践中,这对你没有多大帮助,除非你已经知道如何获得Publisher
.
从 Java 9 开始,您可以使用Flow
API,并且使用org.reactivestreams.FlowAdapters#toPublisher
,您可以将 a 转换Flow.Publisher
为org.reactivestreams.Publisher
. 尽管如此,JDK 只有一个内置的发布者,SubmissionPublisher
而且它可能不是您所需要的。
相反,它是迄今为止最容易使用兼容库的,如 RxJava 或 Spring Reactor。他们使用的类型要么是直接的实例,org.reactivestreams.Publisher
要么是非常容易转换的。
对于使用 RxJava 的示例,您可以从 graphql-java看到这个演示项目。或者来自 SPQR 的这个测试。但是,这两者都过于简单而无法实际使用。
有关更实际的示例,请参阅SPQR Spring Boot Starter 项目中的此演示。它使用 Spring Reactor,无论您是否使用 Spring,您都可以使用它。每次相关突变运行时,该示例都会发布更新。
现在,制作一个Publisher
只是问题的一半。您需要有一种方法将更新发送到客户端。此外,客户端和服务器需要就他们将用来交换消息(新结果、任何遇到的错误以及控制消息)的协议达成一致。目前,只有一种广泛使用的协议存在——Apollo graphql-ws 协议。它基于 WebSockets。
SPQR Spring Boot Starter,从 0.0.3 版本开始,实现了这个协议,因此它可以与 Apollo 客户端一起使用。当然也可以使用其他兼容的客户端,例如GraphQL Playground 。
即使您根本不想使用 SPQR Spring Boot Starter 或 Spring,您仍然可以从那里的示例中学习如何实现服务器。至于客户端,任何 Apollo 教程都会让你继续前进。您可以在测试和开发期间使用 GraphQL Playground(GraphiQL 目前不支持订阅)。