Go语言的GraphQL实践总结

GraphQL 介绍

REST API的使用方式是,server定义一系列的接口,client调用自己需要的接口,获取目标数据进行整合。REST API开发中遇到的问题:

  • 扩展性 ,随着API的不断发展,REST API的接口会变得越来臃肿。
  • 无法按需获取 ,一个返回id, name, age, city, addr, email的接口,如果仅获取部分信息,如name, age,却必须返回接口的全部信息,然后从中提取自己需要的。坏处不仅会增加网络传输量,并且不便于client处理数据
  • 一个请求无法获取所需全部资源 ,例如client需要显示一篇文章的内容,同时要显示评论,作者信息,那么就需要调用文章、评论、用户的接口。坏处造成服务的的维护困难,以及响应时间变长 。
  • 原因: REST API通常由多个端点组成,每个端点代表一种资源。所以,当client需要多个资源是,它需要向REST API发起多个请求,才能获取到所需要的数据。
  • REST API不好处理的问题 , 比如确保client提供的参数是类型安全的,如何从代码生成API的文档等。
  • 避免了 N+1的出现。

如何定义Schema
schema用来描述对于接口获取数据逻辑 ,GraphQL中使用Query来抽象数据的查询逻辑,分为三种,分别是query(查询)、mutation(更改)、subscription(订阅) 。API的接口概括起来有CRUD(创建、获取、更改、删除)四类,query可以覆盖R(获取)的功能,mutation可以覆盖(CUD创建、更改、删除)的功能。

Query

  • query(查询):当获取数据时,选择query类型
  • mutation(更改): 当尝试修改数据时,选择mutation类型
  • subscription(订阅):当希望数据更改时,可以进行消息推送,使用subscription类型(针对当前的日趋流行的real-time应用提出的)。

Powered by Hexo and Hexo-theme-hiker

Copyright © 2018 - 2021 Noonde All Rights Reserved.

UV : | PV :