使用 GraphQL 的 6 个月

Posted 01二进制

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用 GraphQL 的 6 个月相关的知识,希望对你有一定的参考价值。

GraphQL 这个名词已经火了一段时间,但是一直没有体验过,无意中发现了一篇使用体验的文章,就想着翻译下分享给大家,如果翻译有问题的,还望批评指正。译文出自:掘金翻译计划[1]


在使用 GraphQL 进行了 6 个月的后端项目开发后,我开始考量该技术是否适合在开发工作中使用。

首先

GraphQL 是一种实现 API 的查询语言,也是使用现有数据完成这些查询的运行时。GraphQL 为你的 API 中的数据提供了完整且易于理解的描述,并且让用户有权决定他们所需要的东西,仅此而已。

它由 Facebook 开发,作为其移动应用程序的内部解决方案,后来向社区开放了源代码。

优点

务实的数据交换

使用数据加载器(Dataloaders)减少网络调用

虽然 Dataloaders 不是 GraphQL 库本身的一部分,但是它的确是一个很有用的第三方库,可以用来解耦应用程序中不相关的部分,同时不会牺牲批量数据加载的性能。虽然加载器提供了一个加载各个独立值的 API,但是所有并发请求都将被合并起来才分送给你的批处理加载函数。这使你的应用程序可以安全地在整个应用程序进行数据的分发与获取。

这方面的一个例子是,从另一个称为事务服务的服务中获取人的银行信息,后端可以从事务服务中获取银行信息,然后将结果与人的姓名年龄结合起来后作为结果返回。

公开数据和数据库模型之间的解耦

GraphQL 的一大优点是可以将数据库建模数据和给用户公开的数据解耦。这样,在设计持久层时,我们可以专注于该层的需求,然后分别考虑如何采取最好的方式将数据暴露给使用者。这与 dataloader 的使用密切相关,因为你可以在将数据发送给用户之前将它们组合在一起,从而使得公开数据的设计模型变得非常容易。

忘记 API 的版本控制

API 的版本控制是一个常见问题,通常一个简单的解决方案是,在相同的 API 前面添加一个v2标识。但一旦有了 GraphQL,情况就不同了。虽然你仍然可以使用相同的解决方案,但这与 GraphQL 的理念不合。官方文档明确指出你应该改进你的 API,这意味着向已有端点添加更多的字段并不会破坏原有的 API。前端仍然可以使用相同的 API 进行查询,并且可以根据需要查询新字段。这种处理方式真的很巧妙。

在与前端团队协作时,这个特性非常有用。他们可以发出请求,并添加由于设计更改而需要的新字段,而后端可以轻松地添加该字段,同时不会破坏现有的 API。

独立团队

使用 GraphQL,前端和后端可以独立工作。因为 GraphQL 具有严格的类型化架构,因此两个团队可以并行工作互不影响。首先,前端无需查看后端代码即可轻松地生成数据模型,且生成的数据模型可以直接用于创建数据查询。其次,前端可以使用模拟(mock)出来的 API 来测试代码。这样便不会阻碍前后端的开发工作,大大的提升了程序员的开发体验。

缺点

并非所有的 API 都能改进

有时,会因业务或设计而产生一些变化,这需要对 API 的实现进行彻底更改。在这种情况下,你将不得不依靠旧的方式进行版本控制。

不可读的代码

由于经历了多次迭代,所以有时在使用 Dataloader 读取数据时代码会分散到多个位置,这可能很难维护。

响应时间更长

由于查询会不断发展并变得臃肿,因此有可能会延长响应时间。为避免这种情况,请确保简明扼要的响应资源。有关指导原则,请查看Github GraphQL API。[2]

缓存

缓存 API 响应的目的主要是为了更快地从将来的请求中获取响应。与 GraphQL 不同,RESTful API 可以利用 HTTP 规范中内置的缓存。正如前面提到的,GraphQL 查询可以请求资源的任何字段,因此本质上是很难实现缓存的。

结论

我强烈建议使用 GraphQL 替代 REST API。GraphQL 所提供的灵活性绝对可以取代它的痛点。这里提到的优缺点可能并不总适用,但是探索如何借助 GraphQL 来帮助你完成项目是很值得思考的。

如果你有任何意见,请在下面回复。

References

[1] 掘金翻译计划: https://github.com/xitu/gold-miner
[2] Github GraphQL API。: https://developer.github.com/v4/


以上是关于使用 GraphQL 的 6 个月的主要内容,如果未能解决你的问题,请参考以下文章

你如何在 python 中处理 graphql 查询和片段?

重用 GraphQL 片段

在 Java 的 GraphQL 查询中添加片段

有没有办法使用 TypeGraphQL 定义 GraphQL 片段?

GraphQL 查询,根据某些条件使用片段。已加载 GraphQL 文件

GraphQL 片段 JSON 格式