当前位置:新闻中心行业动态 → 正文

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

责任编辑:editor004 作者:Thomas Betts |来源:企业网D1Net  2018-01-16 12:03:08 本文摘自:INFOQ

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

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

关键字:restQL查询语言GitHub

本文摘自:INFOQ

x 微服务查询语言restQL已在GitHub上发布 扫一扫
分享本文到朋友圈
当前位置:新闻中心行业动态 → 正文

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

责任编辑:editor004 作者:Thomas Betts |来源:企业网D1Net  2018-01-16 12:03:08 本文摘自:INFOQ

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

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

关键字:restQL查询语言GitHub

本文摘自:INFOQ

电子周刊
回到顶部

关于我们联系我们版权声明隐私条款广告服务友情链接投稿中心招贤纳士

企业网版权所有 ©2010-2024 京ICP备09108050号-6 京公网安备 11010502049343号

^