良许Linux教程网 干货合集 简单介绍一下graphql

简单介绍一下graphql

graphql 是一种用于 API 的查询语言,对你的 API 中的数据提供了一套易于理解的完整描述,使得客户端能够准确地获得它需要的数据,减少数据的冗余。

image-20220105215248618

对比 Rest API

Rest API 是和 GraphQL 同类的用于查询的语言。Rest 把每个资源都用一个 URL 表示,访问这个 URL 就能够得到一份 JSON 格式的数据响应,但是这有一个缺点,你可能会得到与需求不相关的数据。而 GraphQL 则不会,发送过去的请求中指定了需要哪个资源,举个简单的例子,你需要这本书的作者的姓资源,那么 Rest API 会把把作者的名字也发给你,因为你是通过访问作者的信息的 URL 来获得姓的,而 GraphQL 则会只把需要的信息发过来,换句话说,需要什么资源是用户来决定的。

RPC vs REST vs GraphQL(参考资料点击这里

灵活的API查询语言——GraphQL灵活的API查询语言——GraphQL

在合适的时候选择合适的工具是重要的,下面则列举了在一些场景下最好使用什么工具来作为参考

1、如果是 Management API,这类 API 的特点如下:

  • 关注于对象与资源
  • 会有多种不同的客户端
  • 需要良好的可发现性和文档
  • 这种情景使用 REST + JSON API 可能会更好。

2、如果是 Command or Action API,这类 API 的特点如下:

  • 面向动作或者指令
  • 仅需要简单的交互
  • 这种情况使用 RPC 就足够了。

3、如果是 Internal Micro Services API,这类 API 的特点如下:

  • 消息密集型
  • 对系统性能有较高要求
  • 这种情景仍然建议使用 RPC。

4、如果是 Micro Services API,这类 API 的特点如下:

  • 消息密集型
  • 期望系统开销较低
  • 这种情景使用 RPC 或者 REST 均可。

5、如果是 Data or Mobile API,这类 API 的特点是:

  • 数据类型是具有图状的特点
  • 希望对于高延迟场景可以有更好的优化
  • 这种场景无疑 GraphQL 是最好的选择。

GraphQL 的查询与变更——如何查询 GraphQL 服务器 以一个查询结果为例:

{
hero {
name
}
}

该查询将会获得一个与其结构几乎一样的结果:

{
"data": {
"hero": {
"name""R2-D2"
}
}
}

这是 GraphQL 最重要的特性,因为这样一来,你就总是能得到你想要的数据,而服务器也准确地知道客户端请求的字段。并且在GraphQL中查询是可交互的,你可以按你喜欢来改变查询,然后看看新的结果。

在查询时可以添加上参数,结果也会显得更有趣。参数可以是多种不同的类型。GraphQL 自带一套默认类型,但是 GraphQL 服务器可以声明一套自己的定制类型,只要能序列化成你的传输格式即可。

例如,有如下查询:

{
human(id: "1000") {
name
height
}
}

其结果为:

{
"data": {
"human": {
"name""Luke Skywalker",
"height": 1.72
}
}
}

在类似 REST 的系统中,你只能传递一组简单参数 —— 请求中的 query 参数和 URL 段。但是在 GraphQL 中,每一个字段和嵌套对象都能有自己的一组参数,从而使得 GraphQL 可以完美替代多次 API 获取请求。甚至你也可以给 标量(scalar)字段传递参数,用于实现服务端的一次转换,而不用每个客户端分别转换。

更多GrophQL的类型系统请点击这里

以上就是良许教程网为各位朋友分享的Linu系统相关内容。想要了解更多Linux相关知识记得关注公众号“良许Linux”,或扫描下方二维码进行关注,更多干货等着你 !

img
本文由 良许Linux教程网 发布,可自由转载、引用,但需署名作者且注明文章出处。如转载至微信公众号,请在文末添加作者公众号二维码。
良许

作者: 良许

良许,世界500强企业Linux开发工程师,公众号【良许Linux】的作者,全网拥有超30W粉丝。个人标签:创业者,CSDN学院讲师,副业达人,流量玩家,摄影爱好者。
上一篇
下一篇

发表评论

邮箱地址不会被公开。 必填项已用*标注

联系我们

联系我们

公众号:良许Linux

在线咨询: QQ交谈

邮箱: yychuyu@163.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部