微服务查询语言 restQL 已在 GitHub 上发布

  • Thomas Betts
  • 宋康婧

2018 年 1 月 15 日

话题:REST语言 & 开发架构

看新闻很累?看技术新闻更累?试试下载 InfoQ 手机客户端,每天上下班路上听新闻,有趣还有料!

微服务查询语言restQL已经成为了一个开源项目,使用 MIT 开源许可。restQL 语言旨在简化客户端访问 RESTful 微服务的常用场景,包括并行调用和链式调用。由拉丁美洲最大的电子商务公司 B2W 开发的 restQL,是为了避免FalcorGraphQL这两个更为人熟知的数据查询和管理框架的一些限制而诞生的。

Falcor 仅适用于使用 JavaScript 的客户端,而 restQL 对于任何支持 HTTP REST 调用的客户端都适用。这意味着 restQL 也能适用于使用 Swift 和 Java 编写的移动应用。尽管 GraphQL 现在已经是一种成熟的数据查询语言,但是它不支持一些对 RESTful 服务来说简单或约定俗成的特性,比如 HTTP 响应状态码或者本地浏览器缓存。

与其他查询语言类似,restQL 语句描述了要获取的资源,并用参数进行过滤。比如:

  from hero             
            with  
        name = "Restman"

默认情况下,查询是并行执行的,无须任何特殊语法。对于更复杂也更常见的场景,比如链式调用或者多路复用调用(如下例所示)也非常清晰直观。

  from hero
            with
                name = "Restman"
        from sidekick
            with
                hero = hero.id

对 restQL 查询的解析和响应由 restQL 服务端处理。restQL 服务端是用 Clojure 实现的,它充当着提交 restQL 查询的客户端和后端 APIs 之间的桥梁。所有的配置信息都是存在服务端的,以匹配资源名称和相应的调用端点(endpoint)。由于 restQL 服务端开放了标准的 REST 调用端点,所以不需要专门处理的客户端。

在一篇声明 restQL 的博客文章中,B2W Digital 的 IT 经理,同时也是 restQL 的作者之一的 Ricardo Mayerhofer 提到,这个项目是在公司向微服务迁移的过程中诞生的。开发团队很快从向微服务的迁移中受益,因为应用程序变得更小,相应的维护也更简单。但是,前端代码变得更加复杂了,因为需要向多个微服务发送请求,而不是像以前那样只用向一个整体的服务发送一个请求。Ricardo 总结了他们的经验:“基于微服务的架构并不是什么银弹。尽管能给服务端团队带来直接的好处,但是它的特性给使用者带来了复杂性和性能方面的挑战。”在参考了 Falcor 和 GraphQL 后,restQL 诞生了,并被证明有助于简化客户端对大量后端服务的访问。

你可以在项目主页http://restql.b2w.io/上找到更多关于 restQL 的信息。源代码则在GitHub上。

查看英文原文:restQL, a Microservices Query Language, Released on GitHub

REST语言 & 开发架构