GraphQL, 是一个API的标准: specification.
对于每个新技术, 要搞清楚的6个问题:
GraphQL是相对于REST API的另一种标准.
相对于REST返回固定结构数据的多个endpoints, GraphQL的server只暴露一个endpoint, 由客户端来规定想要的字段和结构, 服务端精确返回client要求的数据.
2012年, Facebook有一个新闻类的iOS app. 随着移动用户增多, 网络请求有设备电量消耗, 弱网环境等问题.
这在当时是一个非常紧迫的issue, 于是他们研究出了GraphQL, 减小了需要发送的请求个数和数据传输量.
2015年Facebook将GraphQL开源.
类似的尝试还有Netflix的Falcor和Coursera, 后者后来取消了自己的effort, 加入了GraphQL的阵营.
GraphQL思想: enables declaratative data fetching.
GraphQL要解决的问题: 优化客户端向服务器请求数据的过程:
GraphQL是一种规范, 具体实现有多种.
和传输层, 数据库, 数据源类型都不相关.
GraphQL应用场景:
理想开发场景: 根据数据, 建立好schema之后, 前后端独立开发, 前端可以根据需要拿到想要的数据.
Schema定义了API的能力, 是server和client之间的协议. 规定了客户端可以请求的数据和类型.
The Schema Definition Language (SDL): Schema Definition Language.
Root Types: Query, Mutation, Subscription.
对应查询, 更改和订阅.
GraphQL服务器只暴露一个endpoint.
在API的设计上, 需要把数据按照Graph来想, 而不是按照endpoints来想, 更专注于描述数据.
对于Schema定义好的结构, Server端对于每个字段实现resolver function, 进行查询.
Server库: https://graphql.org/code/#server-libraries
客户端查询, 更加自主的结构, 字段级别的粒度.
Client库: https://graphql.org/code/#graphql-clients
和Server库一样, 这些库为我们封装了一些样板代码, 简化方便了我们的开发.
queries/mutations都包含一个字段集合.
在server上, 每个字段都有一个resolver function, 用来读取相应字段的数据.
Server上执行的机制:
The query is traversed field by field, executing “resolvers” for each field.
广度优先. 按层级进行.
为了改善效率, JavaScript有dataloader, 把resolver的调用批处理, 减少重复调用.
客户端实际上发送的是POST请求, GraphQL的query作为JSON payload的字段.
可以用curl命令模拟得到相同的效果, 见:
https://graphql.org/graphql-js/graphql-clients/
introspection query可能是唯一的GET请求.
REST的好点子: stateless servers, structured access to resources.
REST的缺点: 快速变化的客户端需求可能和REST的静态属性不合.
REST:
GraphQL更加灵活和有效率.
REST和GraphQL两者可以共存.
原文:https://www.cnblogs.com/mengdd/p/why-graphql-6-questions.html