\u0026#xD;\n\u0026#xD;\n\u0026#xD;\n看新闻很累?看技术新闻更累?试试下载InfoQ手机客户端,每天上下班路上听新闻,有趣还有料!
\u0026#xD;\n
微服务查询语言restQL已经成为了一个开源项目,使用MIT开源许可。restQL语言旨在简化客户端访问RESTful微服务的常用场景,包括并行调用和链式调用。由拉丁美洲最大的电子商务公司B2W开发的restQL,是为了避免Falcor和GraphQL这两个更为人熟知的数据查询和管理框架的一些限制而诞生的。
\u0026#xD;\n\u0026#xD;\nFalcor仅适用于使用JavaScript的客户端,而restQL对于任何支持HTTP REST调用的客户端都适用。这意味着restQL也能适用于使用Swift和Java编写的移动应用。尽管GraphQL现在已经是一种成熟的数据查询语言,但是它不支持一些对RESTful服务来说简单或约定俗成的特性,比如HTTP响应状态码或者本地浏览器缓存。
\u0026#xD;\n\u0026#xD;\n与其他查询语言类似,restQL语句描述了要获取的资源,并用参数进行过滤。比如:
\u0026#xD;\n\u0026#xD;\n\u0026#xD;\n from hero \u0026#xD;\n with \u0026#xD;\n name = \"Restman\"\u0026#xD;\n\u0026#xD;\n\u0026#xD;\n
默认情况下,查询是并行执行的,无须任何特殊语法。对于更复杂也更常见的场景,比如链式调用或者多路复用调用(如下例所示)也非常清晰直观。
\u0026#xD;\n\u0026#xD;\n\u0026#xD;\n from hero\u0026#xD;\n with\u0026#xD;\n name = \"Restman\"\u0026#xD;\n from sidekick\u0026#xD;\n with\u0026#xD;\n hero = hero.id\u0026#xD;\n\u0026#xD;\n\u0026#xD;\n\u0026#xD;\n
对restQL查询的解析和响应由restQL服务端处理。restQL服务端是用Clojure实现的,它充当着提交restQL查询的客户端和后端APIs之间的桥梁。所有的配置信息都是存在服务端的,以匹配资源名称和相应的调用端点(endpoint)。由于restQL服务端开放了标准的REST调用端点,所以不需要专门处理的客户端。
\u0026#xD;\n\u0026#xD;\n在一篇声明restQL的博客文章中,B2W Digital的IT经理,同时也是restQL的作者之一的Ricardo Mayerhofer提到,这个项目是在公司向微服务迁移的过程中诞生的。开发团队很快从向微服务的迁移中受益,因为应用程序变得更小,相应的维护也更简单。但是,前端代码变得更加复杂了,因为需要向多个微服务发送请求,而不是像以前那样只用向一个整体的服务发送一个请求。Ricardo总结了他们的经验:“基于微服务的架构并不是什么银弹。尽管能给服务端团队带来直接的好处,但是它的特性给使用者带来了复杂性和性能方面的挑战。”在参考了Falcor和GraphQL后,restQL诞生了,并被证明有助于简化客户端对大量后端服务的访问。
\u0026#xD;\n\u0026#xD;\n你可以在项目主页http://restql.b2w.io/上找到更多关于restQL的信息。源代码则在GitHub上。
\u0026#xD;\n\u0026#xD;\n查看英文原文:restQL, a Microservices Query Language, Released on GitHub