BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

GitHub采用了新的GraphQL API

| 作者 Margot Krouwer 关注 5 他的粉丝 ,译者 Rays 关注 3 他的粉丝 发布于 2016年10月18日. 估计阅读时间: 4 分钟 | CNUTCon 了解国内外一线大厂50+智能运维最新实践案例。

近期在GitHub全球大会上,GitHub推出了新API的alpha预览版,该版API使用Facebook的GraphQL(一种允许自服务API契约的查询语言)编写。GitHub在其工程博客写道,GitHub对API范式的转换主要是因为现有的RESTful契约缺乏可扩展性。为迎合大量各异客户的需求,REST不能在提供GitHub所需灵活性的同时维持较低的维护代价。

GitHub将现有API迁移到GraphQL的公告,与数日后Facebook将最终移除其服务的“技术预览”绰号的决定是遥相呼应的。虽然早自2002年起,GraphQL就已用于Facebook的生产环境中,但由于直至最近GraphQL的九月中期版本才得以开源,所以其在技术上依然是一个“预览版”。总体而言,社区对GraphQL表现出复杂的反应,一些人宣称GraphQL给服务器端代码带来了不公平的额外复杂度和管理,也有一些人对GraphQL分隔各种个体消费者的数据消费需求和核心数据本身的能力青睐有加,认为这将使API更具可扩展性和多样性。GitHub在其工程博客上这样地描述当前的API:“不管我们提供了多少信息,来自集成商那里的反馈依然认为我们的REST API还不够灵活。有时为构成对一个资源的完整视图,需要做两次或三次单独调用。看上去尽管我们的响应同时发送了太多的数据,但是其中并未包括用户所需的数据。”这里Github暗示GraphQL非常适合于具有大量各异客户的应用场景,其中客户对底层数据具有复杂规模的需求。而对于为一个并没有多少开发人员消费的简单网站提供API,GraphQL并不能体现出其相对于REST的优越性。

在其工程博客中,GitHub指出其API的历史开始于2008年。其中提及Github的第一个RESTful API成为了很多企业的样板,彼时这些企业正为精雕细琢其自身的REST API而寻找实例模板。GitHub希望GraphQL能像其首次涉足REST时那样,为那些寻求很好的方式去从多消费者复杂数据需求中受益的开发人员和企业树立样板。正如在GraphQL技术预览版发布后的InfoQ文章中,GraphSQL的早期贡献者之一Lee Byron所说的:“社区不仅在使用GraphQL,同时也在创建它。”作为GraphQL的首批主流用户之一,GitHub自采用GraphQL以来就一直在转变它。在GitHub上,GraphQL已从其早期的JavaScript构建,转变为使用从Java到C#和Ruby(Ruby是GitHub自身也在使用的)等多种语言构建,现在平台上已有种类繁多的开源工具。

虽然看上去GitHub转到GraphQL的主要原因是为了实现适合各种客户所需的可扩展性,但是GitHub也提及很多额外的优点。在其技术博客中这样写道:“GraphQL代表了API开发中的一个巨大飞跃。类型安全、内省、文档生成和可预测响应,这使我们平台的维护者和客户均可从中受益。”考虑到GitHub当前所呈现出的数据规模,文档生成和内省有益于数据的消费。此外,Swagger等工具非常有助于RESTful API的文档化,GitHub确需贯穿整个代码库的手工注解创建,这些注解易于变成和代码注释一样的陈旧。GitHub可以使用GraphQL所包括的所有工具,与相应的API改变和必要的API文档一起发布其中的软件,这对于GitHub及其用户而言均为一个重大利好。

查看英文原文:GitHub Adopts New GraphQL API


感谢夏雪对本文的审校。

给InfoQ中文站投稿或者参与内容翻译工作,请邮件至editors@cn.infoq.com。也欢迎大家通过新浪微博(@InfoQ@丁晓昀),微信(微信号:InfoQChina)关注我们。

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我
社区评论

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT