配置API级联
概述
API级联是指同一区域或不同区域的两个ROMA Connect实例可以建立级联关系,级联实例中的API可以使用被级联实例中的API作为后端服务,实现跨实例间的API调用。级联实例间的API调用使用专属的认证通道,避免被级联实例的API作为后端服务时的认证冲突问题。
- 级联实例:使用其他实例中的API作为后端服务的实例。
- 被级联实例:把API提供给其他实例作为后端服务的实例。
对于API的提供者,可以通过级联方式把实例内的API提供给另外一个实例去使用,从而提升API资产的复用能力,避免在多个不同实例中重复部署后端服务。
前提条件
- 级联的实例间网络可以互通。
- 级联的实例间跨网互通时,如果经过网闸设备,需要将级联实例和被级联实例的地址和端口提供给网闸设备,并在网闸设备中采用TCP协议摆渡方式打通网络路径。也可以通过专用VPN或隧道来实现跨网互通。
操作步骤
- 在被级联实例配置级联功能。
- 登录被级联实例所在的ROMA Connect控制台,在“实例”页面单击实例上的“查看控制台”,进入实例控制台。
- 在“实例信息”页面选择“配置参数”页签,并找到级联功能开关参数“cascade”。
- 单击参数右侧的“编辑”,把参数运行值设置为“on”,然后单击“保存”,打开级联功能开关。
- 单击参数左侧的“”,展开并配置级联相关配置参数。
表1 被级联实例配置 参数
配置说明
cascade_auth_key
级联认证的加密密钥,用于级联API之间的调用认证。被级联实例和级联实例的cascade_auth_key值必须配置一致。
cascade_instance_ids
级联实例的实例ID列表,仅允许的实例可级联到当前实例。多个实例ID之间使用英文逗号(,)隔开,最多支持配置5个实例ID。
- 在级联实例配置级联功能。
- 登录级联实例所在的ROMA Connect控制台,在“实例”页面单击实例上的“查看控制台”,进入实例控制台。
- 在“实例信息”页面选择“配置参数”页签,并找到级联功能开关参数“cascade”。
- 单击参数右侧的“编辑”,把参数运行值设置为“on”,然后单击“保存”,打开级联功能开关。
- 单击参数左侧的“”,展开并配置级联相关配置参数。
表2 级联实例配置 参数
配置说明
cascade_auth_key
级联认证的加密密钥,用于级联API之间的调用认证。被级联实例和级联实例的cascade_auth_key值必须配置一致。
cascade_instance_ids
级联实例的实例ID列表,级联实例中无需配置该参数。
- 在级联实例创建到被级联实例的负载通道。
- 在级联实例控制台左侧的导航栏选择“服务集成 APIC > API管理”,在“负载通道”页签中单击“创建负载通道”。
- 在新建负载通道页面配置负载通道基本信息和健康检查配置,完成后单击“下一步”。
表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响应码时,判定响应成功。可同时指定多个响应码。
- 单击“添加后端服务器地址”,在页面中配置被级联实例的地址信息。
表4 后端服务器配置 参数
配置说明
后端服务器地址
填写被级联实例的API访问地址。
- 若填写IP地址:
- 级联的实例间基于弹性IP实现公网互通时,则填写被级联实例的“弹性IP地址”。
- 级联的实例间基于VPC内网地址实现内网互通时,则填写被级联实例的“服务集成 APIC连接地址”。
- 若填写域名,则填写API的访问域名地址。
权重
仅当负载通道的“分发算法”选择“加权轮询”或“加权最小连接”时需要配置。
填写后端服务器的权重值,权重值越大,转发到该服务器的请求数量越多。
- 若填写IP地址:
- 单击“完成”,完成负载通道的创建。
- 在级联实例创建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作为后端服务时,不启用后端认证。