GraphQL 是一种用于构建 API 的查询语言,它使得客户端能够精确地请求所需的数据。在 GraphQL 中,Schema 是定义数据类型和查询的核心部分。Schema Stitching 是一种将多个 GraphQL Schema 组合成一个 Schema 的方法,使得客户端可以通过单一的入口点访问所有服务。
为什么需要 Schema Stitching?
在现代应用程序中,通常有多个服务提供数据。这些服务可能是微服务或者由不同团队维护的独立服务。在这种情况下,每个服务都会有自己的 GraphQL Schema。但是,客户端需要通过一个入口点来访问这些服务。如果客户端需要访问多个服务,则需要发起多个请求。这样会增加网络延迟和复杂性。Schema Stitching 可以将多个服务的 Schema 合并成一个 Schema,使得客户端可以通过单一的入口点访问所有服务。
Schema Stitching 的实现
Schema Stitching 可以通过多种方式实现。以下是两种常用的方式。
1. Apollo Federation
Apollo Federation 是一种基于 GraphQL 的微服务框架,它使用 Schema Stitching 将多个服务的 Schema 组合成一个 Schema。在 Apollo Federation 中,每个服务都有自己的 Schema,这些 Schema 通过共享类型来相互连接。这些类型称为共享类型,它们定义了服务之间的关系。共享类型可以在不同服务的 Schema 中定义,然后在组合 Schema 中进行 Stitching。
以下是一个示例代码,其中包含两个服务的 Schema:
-- -------------------- ---- ------- -- ------- - ---- ---- - --- --- ----- ------- - ---- ----- - -------- ----- ---- - -- ------- - ---- ---- - --- --- ------ ------- --------- --- - ---- ----- - -------- ----- ---- -
在上面的示例中,Service A 定义了 User 类型和 user 查询,Service B 定义了 Post 类型和 post 查询。这两个服务之间有一个关系,即 Post 类型中的 authorId 字段与 User 类型中的 id 字段相对应。为了将这两个服务的 Schema 组合成一个 Schema,需要共享 User 类型。以下是组合后的 Schema:
-- -------------------- ---- ------- -- -------- ------ ---- ---- - --- --- ----- ------- - ---- ---- - --- --- ------ ------- ------- ---- - ---- ----- - -------- ----- ---- -------- ----- ---- -
在组合后的 Schema 中,Post 类型中的 author 字段使用了 User 类型。这个字段是通过 Schema Stitching 自动创建的,它使用了共享类型 User。
2. GraphQL Tools
GraphQL Tools 是一个用于构建 GraphQL Schema 的库,它提供了一些工具和函数来帮助开发人员构建和组合 Schema。其中一个功能是 Schema Stitching。使用 GraphQL Tools,可以将多个 Schema 组合成一个 Schema,然后使用 Apollo Server 将其作为单个 API 提供。
以下是一个示例代码,其中包含两个服务的 Schema:
-- -------------------- ---- ------- -- ------- - ---- ---- - --- --- ----- ------- - ---- ----- - -------- ----- ---- - -- ------- - ---- ---- - --- --- ------ ------- --------- --- - ---- ----- - -------- ----- ---- -
在上面的示例中,Service A 定义了 User 类型和 user 查询,Service B 定义了 Post 类型和 post 查询。这两个服务之间有一个关系,即 Post 类型中的 authorId 字段与 User 类型中的 id 字段相对应。为了将这两个服务的 Schema 组合成一个 Schema,需要使用 GraphQL Tools 中的 mergeSchemas 函数。以下是组合后的 Schema:
-- -------------------- ---- ------- -- -------- ------ ---- ---- - --- --- ----- ------- - ---- ---- - --- --- ------ ------- ------- ---- - ---- ----- - -------- ----- ---- -------- ----- ---- -
在组合后的 Schema 中,Post 类型中的 author 字段使用了 User 类型。这个字段是通过 Schema Stitching 自动创建的,它使用了 Service A 中的 User 类型。
总结
Schema Stitching 是一种将多个 GraphQL Schema 组合成一个 Schema 的方法,使得客户端可以通过单一的入口点访问所有服务。这个过程可以通过多种方式实现,例如使用 Apollo Federation 或 GraphQL Tools。Schema Stitching 可以提高应用程序的性能和可维护性,减少网络延迟和复杂性。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/656d8807d2f5e1655d5c8532