dgate - 基于 Vert.x 的 API gateway


Apache
跨平台
Java

软件简介

dgate 是基于 Vertx 的 API Gateway。运行 dgate 的命令如下:

java -jar dgate-version-fat.jar -Dconf=conf

其中的 conf 属性用来指定运行所需的配置文件。

conf的文件格式

dgate采用ConfigSlurper解析conf文件,因此其文件的语法实际上是Groovy语法。

conf文件由多个Api Gateway的定义组成,对于每个Gateway定义如下:

apiGatewayName {
    port //端口
    login //后端login服务的url,其值为urls中的一个url
    urls { URL配置(UrlConfig)列表 } //dgate暴露的url列表
}

对于每个URL配置,其结构如下:

url {
    required //必需参数列表
    methods  //支持的HTTP Method
    upstreamURLs { 上游URL列表(UpStreamURL) }
    expected //期望返回值
}

其中:

  • required支持两种格式:List和Map。前者适用于不区分HttpMethod时的参数验证,后者则可以针对不同的HttpMethod分别进行设置。

    • List,如:required = [“sub”, “password”]

    • Map,如:required = [get: [‘param1’], post: [‘param2’], delete: [‘param3’]]

  • expected和upStreamURLs两个属性不能并存

  • expected主要用于mock模式,其目的是为了便于依赖dgate的访问层可以自行mock所需的响应,使得它们的开发进度受dgate开发进度的影响最小化。

  • 对于expected的内容:

    • statusCode和payload至少有一个

    • 或针对具体的HTTP METHOD的返回值

  • 对于每个上游URL,有3个属性:host、port和url,其中url必需以”/”开始