更新时间:2022-12-05 GMT+08:00

配置API级联

概述

API级联是指同一区域或不同区域的两个ROMA Connect实例可以建立级联关系,级联实例中的API可以使用被级联实例中的API作为后端服务,实现跨实例间的API调用。级联实例间的API调用使用专属的认证通道,避免被级联实例的API作为后端服务时的认证冲突问题。

  • 级联实例:使用其他实例中的API作为后端服务的实例。
  • 被级联实例:把API提供给其他实例作为后端服务的实例。

对于API的提供者,可以通过级联方式把实例内的API提供给另外一个实例去使用,从而提升API资产的复用能力,避免在多个不同实例中重复部署后端服务。

前提条件

  • 级联的实例间网络可以互通。
  • 级联的实例间跨网互通时,如果经过网闸设备,需要将级联实例和被级联实例的地址和端口提供给网闸设备,并在网闸设备中采用TCP协议摆渡方式打通网络路径。也可以通过专用VPN或隧道来实现跨网互通。

操作步骤

  1. 在被级联实例配置级联功能。
    1. 登录被级联实例所在的ROMA Connect控制台,在“实例”页面单击实例上的“查看控制台”,进入实例控制台。
    2. 在“实例信息”页面选择“配置参数”页签,并找到级联功能开关参数“cascade”。
    3. 单击参数右侧的“编辑”,把参数运行值设置为“on”,然后单击“保存”,打开级联功能开关。
    4. 单击参数左侧的“”,展开并配置级联相关配置参数。
      表1 被级联实例配置

      参数

      配置说明

      cascade_auth_key

      级联认证的加密密钥,用于级联API之间的调用认证。被级联实例和级联实例的cascade_auth_key值必须配置一致。

      cascade_instance_ids

      级联实例的实例ID列表,仅允许的实例可级联到当前实例。多个实例ID之间使用英文逗号(,)隔开,最多支持配置5个实例ID。

  2. 在级联实例配置级联功能。
    1. 登录级联实例所在的ROMA Connect控制台,在“实例”页面单击实例上的“查看控制台”,进入实例控制台。
    2. 在“实例信息”页面选择“配置参数”页签,并找到级联功能开关参数“cascade”。
    3. 单击参数右侧的“编辑”,把参数运行值设置为“on”,然后单击“保存”,打开级联功能开关。
    4. 单击参数左侧的“”,展开并配置级联相关配置参数。
      表2 级联实例配置

      参数

      配置说明

      cascade_auth_key

      级联认证的加密密钥,用于级联API之间的调用认证。被级联实例和级联实例的cascade_auth_key值必须配置一致。

      cascade_instance_ids

      级联实例的实例ID列表,级联实例中无需配置该参数。

  3. 在级联实例创建到被级联实例的负载通道。
    1. 在级联实例控制台左侧的导航栏选择“服务集成 APIC > API管理”,在“负载通道”页签中单击“创建负载通道”。
    2. 在新建负载通道页面配置负载通道基本信息和健康检查配置,完成后单击“下一步”。
      表3 基本信息和健康检查配置

      参数

      配置说明

      通道名称

      填写负载通道的名称,根据规划自定义。建议您按照一定的命名规则填写负载通道名称,方便您快速识别和查找。

      端口

      填写负载通道的服务器访问端口号。根据被级联实例中API使用的请求协议来确定端口号,HTTP协议使用80端口,HTTPS协议使用443端口。

      成员类型

      选择负载通道中的服务器成员类型,访问被级联实例的API时需要选择“IP”类型。

      分发算法

      选择后端服务请求的分发算法,负载通道通过分发算法确定请求被发送到哪台服务器上。

      协议

      选择健康检查所使用的协议,可选择“TCP”、“HTTP”和“HTTPS”。

      路径

      仅当“协议”选择“HTTP”或“HTTPS”时需要配置。

      填写健康检查的URL地址路径。

      Method

      仅当“协议”选择“HTTP”或“HTTPS”时需要配置。

      选择健康检查所使用的HTTP请求方法,可选择“GET”和“HEAD”。

      高级设置

      检查端口

      健康检查的目标端口,默认使用负载通道配置的端口号。

      正常阈值

      执行健康检查时,判定服务器状态正常的连续检查成功次数。例如“正常阈值”设置为“2”,则在连续2次检查成功时,判定服务器的状态正常。

      异常阈值

      执行健康检查时,判定服务器状态异常的连续检查失败次数。例如“异常阈值”设置为“5”,则在连续5次检查失败时,判定服务器的状态异常。

      超时时间

      健康检查的响应超时时间,单位为秒,超过时间无响应则认为检查失败。

      间隔时间

      连续两次检查的间隔时间,单位为秒。

      HTTP响应码

      仅当“协议”选择“HTTP”或“HTTPS”时需要配置。

      服务器在返回指定的HTTP响应码时,判定响应成功。可同时指定多个响应码。

    3. 单击“添加后端服务器地址”,在页面中配置被级联实例的地址信息。
      表4 后端服务器配置

      参数

      配置说明

      后端服务器地址

      填写被级联实例的API访问地址。

      • 若填写IP地址:
        • 级联的实例间基于弹性IP实现公网互通时,则填写被级联实例的“弹性IP地址”。
        • 级联的实例间基于VPC内网地址实现内网互通时,则填写被级联实例的“服务集成 APIC连接地址”。
      • 若填写域名,则填写API的访问域名地址。

      权重

      仅当负载通道的“分发算法”选择“加权轮询”或“加权最小连接”时需要配置。

      填写后端服务器的权重值,权重值越大,转发到该服务器的请求数量越多。

    4. 单击“完成”,完成负载通道的创建。
  4. 在级联实例创建API,使用被级联实例中的API作为后端服务。

    创建API的过程请参考创建API,仅定义后端服务的配置有如下区别。

    表5 API后端服务配置

    参数

    配置说明

    后端服务类型

    选择后端服务的类型。使用被级联实例的API作为后端服务时,需选择“HTTP/HTTPS”。

    协议

    选择后端服务使用的请求协议,根据被级联实例中API的请求协议选择。

    请求方式

    选择后端服务的请求方法,根据被级联实例中API的请求方法选择。

    使用负载通道

    是否使用负载通道访问后端服务。使用被级联实例的API作为后端服务时,需选择“使用”。

    负载通道

    选择访问后端服务所使用的负载通道,选择3所创建的负载通道。

    级联标识

    是否使用级联方式访问后端服务,选择开启。

    自定义host头域

    自定义后端服务请求中的Host头域。若3中创建负载通道时,“后端服务器地址”填写了IP地址,则此处需要填写被级联实例的API的域名。

    后端请求Path

    填写后端服务的请求路径,格式如:/getUserInfo/{userId}。请求路径中可包含Path参数,以{参数名}形式表示。

    如果请求路径中需要携带环境变量,则使用“#变量名#”的形式将环境变量添加到请求路径中,如/#path#。支持添加多个环境变量,如/#path##request#。

    后端超时

    后端服务请求的超时时间,默认为5000ms。

    双向认证

    仅当“协议”选择“HTTPS”时可配置。

    选择是否在ROMA Connect和后端服务间启用双向认证。使用被级联实例的API作为后端服务时,不启用双向认证。

    后端认证

    选择是否启用后端认证。使用被级联实例的API作为后端服务时,不启用后端认证。