简单介绍一下graphql

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

对比 Rest API

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

RPC vs REST vs 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的类型系统请点击这里

原创文章,作者:晴川运维,如若转载,请注明出处:https://baike.qcidc.com/6021.html

(0)
晴川运维晴川运维
上一篇 2025年6月8日
下一篇 2025年6月8日

相关推荐

  • 详解Python虚拟环境virtualenv

    VirtualEnv用于在一台机器上创建多个独立的python运行环境,VirtualEnvWrapper为前者提供了一些便利的命令行上的封装。 了解虚拟环境 如果在一台机器上,想…

    Linux系统 2天前
  • ldconfig命令使用方法

    ldconfig是一个动态链接库管理命令,其目的为了让动态链接库为系统所共享,本篇文章重点为大家讲解一下ldconfig命令使用方法,有需要的小伙伴可以参考一下。 ldconfig…

    Linux系统 2天前
  • Linux中配置HAProxy实现Web负载均衡

    HAProxy 是一款提供高可用性、负载均衡以及基于TCP(第四层)和HTTP(第七层)应用的代理软件,支持虚拟主机,它是免费、快速并且可靠的一种解决方案。 一、测试环境 HAPr…

    Linux系统 2天前
  • 通过haproxy+keepalived实现高可用配置

    HAProxy提供高可用性、负载均衡以及基于TCP和HTTP应用的代理,它是免费、开源、快速并且可靠的一种解决方案。 haproxy能够实现的功能 4层负载均衡,透明代理,7层负载…

    Linux系统 2025年6月10日
  • Linux Tee 命令使用实例

    Linux继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。在执行Linux命令时,我们既想把输出保存到文件中,又想在屏幕上看到输出内容,那么可以用到tee…

    Linux系统 2025年6月8日
  • 使用ACL工具备份和恢复Linux的文件权限

    作为一个系统管理 ,我们的首要任务将是保护和未经授权的访问安全的数据。 我们都知道我们设置使用一些像CHMOD,CHOWN,chgrp命令 ……等有用的Linux命令然而,这些缺省…

    Linux系统 2025年6月13日
  • 浅谈Base64编码原理

    Base64是一种基于64个可打印字符来表示二进制数据的表示方法。由于 2的6次方是64,所以每6个比特为一个单元,对应某个可打印字符。3个字节有24个比特,对应于4个Base64…

    Linux系统 4天前
  • Linux su命令:用户间切换(包含su和su -的区别)

    su 是最简单的用户切换命令,通过该命令可以实现任何身份的切换,包括从普通用户切换为 root 用户、从 root 用户切换为普通用户以及普通用户之间的切换。 普通用户之间切换以及…

    Linux系统 2025年6月8日
  • 跨平台 canvas 绘图框架SpriteJS

    SpriteJS 是一款由 360 奇舞团开源的跨终端 canvas 绘图库,可以基于 canvas 快速绘制结构化 UI 、动画和交互效果,并发布到任何拥有 canvas 环境的…

    Linux系统 2025年6月8日
  • Linux下使用Linfo显示服务器运行状况

    Linfo 是一个自由开源的跨平台的服务器统计 UI 或库,它可以显示大量的系统信息。Linfo 是可扩展的,通过 composer,很容易使用 PHP5 库以程序化方式获取来自 …

    Linux系统 2025年6月8日

发表回复

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