微服务的IDL
微服务的消费者和提供者之间总要有个约定。不跨语言的话,这种语言本身的定义就可以在不同的组件之间直接共享。一旦支持多语言,用一种公共的接口定义语言来定义他们之间的接口能力就是有必要的了,当然这个IDL可以是自动生成出来的。对于这种IDL,需要如下特性:
1. 人要易读
2. 机器能校验
IDL作为一种描述语言,很多RPC框架都提供自己的定义格式。真的特定的格式,他们都会提供编译器,用于理解这些IDL语言,并根据需要进行校验或者进行转换。这种语言的设计者会尽量考虑人的易读性和易写性。设计这种语言以及实现一个相应的语法解析器,有很多的工具,诸如LEX,ANTLR, JavaCC,Bison等等。
除了自己设计一种新的表达语言,使用现有的描述语言来进行接口的描述也是可行的。例如:WSDL就是使用的XML来描述WebService的接口的。JSON,YAML这些描述性的语言也可以用于描述接口。使用这些已经存在的描述语言有如下好处:
1. 大家都已经比较熟悉基础用法了;
2. 找个解析器很容易,各种语言几乎都有,而且因为语法简单,就算自己实现一个也很容易;
3. 各类书写工具,校验工具也很多;
当然,比起专业设计的IDL,使用这些现成的描述语言描述接口还是不是那么的直观。只能说基本够用。
我们可以尝试使用JSON来描述一个接口:
{