🚀 REST API 还是 ✈️ GraphQL ❓

前言

说到 API 设计,GraphQLRESTful API 是当前最主流的两种选择,各自有其独特优势与挑战。

有幸的是,我上家公司的时候,使用的就是 GraphQL,而在上上家使用的是 RESTful API

今天我就结合我的经验,来聊聊到底该如何选择!

往期精彩推荐

正文

GraphQL 优劣势

GraphQLFacebook 推出的声明式查询语言,它的最大优势在于灵活和高效。

你只需要请求自己需要的字段,减少冗余数据传输,可以很大程度上优化性能。

另外,相比 REST 的多次接口调用,GraphQL 支持聚合请求,有效减少 HTTP 请求次数。

还有个好处是,它通过 Schema 统一前后端对接口结构的认知,配合类型提示、Mock 能力,大大提升开发体验。

比如借助代码生成工具 ApolloRelay,可以自动生成对应的查询代码!

最后,天然支持 Subscription,适用于聊天、通知等实时性强的业务场景!

当然,它的劣势也很明显:

不像 REST 可以使用 HTTP 缓存,GraphQL 的缓存需要借助 Apollo 等第三方库维护!

前面提到,虽然可以聚合请求,但是所有请求集中在一个端点,可能会成为系统瓶颈,尤其在高并发场景下!

RESTful API 优劣势

RESTful API 是目前最广泛使用的接口规范,基于 HTTP 协议,使用资源路径和请求方法组合完成数据操作。

它的设计清晰直观,GET/POST/PUT/DELETE 等操作语义明确。

而且生态成熟,社区和工具链完善,日志、监控、安全机制等配套方案多。

最重要的是支持 HTTP 缓存机制,天然支持浏览器或中间层缓存,提升接口性能!

而且通过 Postmancurl 等工具即可快速测试和验证接口。

Apifox Swagger Postman

但它也存在一些问题:

比如,请求冗余,无法控制字段粒度,常常返回大量用不到的数据!

多端聚合困难,遇到复杂业务需要多次请求多个接口,增加开发成本。

还有就是扩展性不如 GraphQL,对于需要动态字段、自定义响应结构的场景,REST 显得不够灵活!

最后

GraphQLREST 各有千秋,关键在于选择适合自己团队和项目的方案。小团队、简单业务选 REST,快准稳;复杂系统、多端协作选 GraphQL,灵活高效。不被技术趋势绑架,做最合适的技术决策,才是架构的本质。

今天的分享就这些了,感谢大家的阅读,如果文章中存在错误的地方欢迎指正!

往期精彩推荐

相关推荐
我爱鸿蒙开发7 分钟前
🥇聊聊鸿蒙的一端开发,多端部署。
前端·开源·harmonyos
前端付杰7 分钟前
深入理解 IndexedDB:索引与游标查询的高效应用
前端·javascript·indexeddb
best6668 分钟前
前端项目SVG展示方案总结,以Vue3+TS为例
前端
啊花是条龙8 分钟前
Angular 开发指南:组件、数据绑定、指令、服务、HTTP、路由和表单
前端·angular.js
bilibilibiu灬8 分钟前
解析Vue 3中 `trigger` 函数是如何触发 DOM 更新的
vue.js
小桥风满袖9 分钟前
Three.js-硬要自学系列12 (各种贴图的综合应用)
前端·css·three.js
雪中何以赠君别11 分钟前
【组件开发】基于 Vue 3 和 Element Plus 的花名册表头设置组件(el-table动态设置表头组件开发)
vue.js
溪饱鱼11 分钟前
秒杀传统数据库!Cloudflare D1 + Drizzle组合拳,高并发高可用,让我们的成本爆降10倍 - D1
前端·后端
Dgua12 分钟前
小程序开发background-image不显示的问题
前端·抖音小程序
作曲家种太阳12 分钟前
第二章节 响应式原理介绍-【手摸手带你实现一个vue3】
前端