<返回更多

技术选型:如何选择REST、GraphQL 和 gRPC

2023-03-17  今日头条  迷路的架构师
加入收藏

REST、GraphQL 和 gRPC 是现代 Web 应用程序中最流行的 3 种 API 开发技术。那么在做技术选型时,三者要如何选择呢?

在本文中,我们将一起对比 REST、GraphQL 和 gRPC 的特性和用法。

REST——最流行的技术

 

 

REST

Representational State Transfer (REST) 是现代 Web 开发中最流行的 API 开发技术。它是一个无状态的数据传输架构。客户端请求时会包含该请求所需的所有详细信息,但是服务器不保留客户端的状态。

REST API 支持 HTTP 原生缓存 header 并使用 HTTP 方法(POST、GET、PUT、PATCH 和 DELETE)来操作数据。因为 REST 的学习门槛较低,所以大家都能轻松使用 REST。

REST 易于扩展且可靠,如果我们还在犹豫不决时,可以优先选择它。

REST的好处

REST的缺点

何时选择 REST

如果没有特定要求,REST 是最佳选择。如果是开发新手,那么使用 REST 是完美的选择,因为它的学习曲线较浅。此外,它还拥有庞大的生态系统,你可以轻松找到问题的解决方案。

在处理较大的请求量和带宽有限时最好使用 REST,因为可以使用它的缓存支持来提高性能。

总的来说,如果你的应用程序没有明确需要使用 GraphQL 或 gRPC,那么就可以使用 REST。

GraphQL——客户端驱动的标准

 

 

GraphQL 是 2015 年推出的一种数据查询语言,支持开发人员精确定位和获取他们需要的数据。与 REST 相比,GraphQL 是一种客户端驱动的方法,客户端可以决定需要什么数据、如何获取数据和格式。它还解决了过度获取和获取不足的问题,因为客户端可以明确指定所需的数据。

GraphQL 使用查询、变更和订阅来操作数据。

Github 是使用 GraphQL 的最大公司之一。它在 2016 年从 REST 转向 GraphQL,极大地帮助了 GitHub 的快速增长。

GraphQL 的好处

GraphQL 的缺点

何时选择 GraphQL

当查询包含数据库的许多记录时,GraphQL 是最佳选择。你可以使用 GraphQL 消除过度获取,并仅查询必要数据以提高应用程序性能。此外,GraphQL 非常适合需要从多个资源聚合数据的情况。

当你还不完全了解客户端使用 API 的原理时,也可以使用 GraphQL。使用 GraphQL 时,你无需预先定义严格的协议,可以根据客户反馈逐步构建 API。

gRPC——一种以性能为导向的技术

 

 

gRPC 是 google 于 2016 年推出的远程过程调用的进化版本。它是一种轻量级解决方案,使用最少的资源提供最大的性能。

gRPC 遵循基于协议的通信方法。它要求客户端和服务器在开始通信之前都有协议。gRPC 使用 Protobuf(一种声明性语言)创建协议,并使用选定的语言为客户端和服务器生成兼容的代码。

gRPC支持的通信方式有4种:

gRPC 的好处

gRPC 的缺点

何时选择 gRPC

  1. 需要高效的数据传输:由于gRPC使用二进制协议,因此比JSON和XML等文本协议更快、更轻量级。
  2. 需要高可靠性:gRPC的基于HTTP/2协议的传输层提供了许多功能,例如流控制、连接复用和头部压缩等,这些功能可以提高可靠性和性能。
  3. 需要高效的多语言通信:gRPC支持多种编程语言,并提供了自动生成代码的工具,因此不需要手动编写跨语言的代码。
  4. 需要支持多种请求和响应类型:gRPC支持四种类型的通信方式(Unary、Server streaming、Client streaming和Bidirectional streaming),因此可以选择最适合特定用例的通信方式。
  5. 需要更好的API管理:gRPC提供了强大的API管理工具,例如gRPC-Gateway和Envoy等,这些工具可以提高API的可发现性、文档化和测试。

gRPC 可以用在微服务架构中来处理服务之间的通信,因为它可以与用不同语言编写的服务进行通信。

结论

选择REST、GraphQL和gRPC取决于你的具体场景和需求,基本原则总结如下:

  1. REST:REST适合简单的API和Web服务,例如传统的CRUD操作。它通常更易于理解和使用,并且具有广泛的支持和工具生态系统。
  2. GraphQL:GraphQL适合需要灵活性和高级查询功能的应用程序。如果你的应用程序需要从多个资源聚合数据,或者需要更好地控制数据的格式和粒度,则GraphQL是一个不错的选择。
  3. gRPC:gRPC适合需要高效和可靠数据传输的应用程序。如果你需要在多种编程语言之间进行高效通信,并且希望提供更高的性能和可靠性,则gRPC是一个不错的选择。

不过,REST、GraphQL和gRPC并不是相互排斥的选择。在实际情况下,你可以结合使用,以满足具体需求和场景。

声明:本站部分内容来自互联网,如有版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
▍相关推荐
更多资讯 >>>