更新时间:2024-11-11 GMT+08:00
分享

查看VPC通道详情

功能介绍

查看指定的VPC通道详情

调用方法

请参见如何调用API

URI

GET /v2/{project_id}/apigw/instances/{instance_id}/vpc-channels/{vpc_channel_id}

表1 路径参数

参数

是否必选

参数类型

描述

project_id

String

项目ID,获取方式请参见获取项目ID

instance_id

String

实例ID,在API网关控制台的“实例信息”中获取。

vpc_channel_id

String

VPC通道的编号

请求参数

表2 请求Header参数

参数

是否必选

参数类型

描述

X-Auth-Token

String

用户Token。通过调用IAM服务获取用户Token接口获取(响应消息头中X-Subject-Token的值)。

响应参数

状态码: 200

表3 响应Body参数

参数

参数类型

描述

name

String

VPC通道的名称。

长度为3 ~ 64位的字符串,字符串由中文、英文字母、数字、中划线、下划线、点组成,且只能以英文或中文开头。

说明:

中文字符必须为UTF-8或者unicode编码。

port

Integer

VPC通道中主机的端口号。

取值范围1 ~ 65535。

balance_strategy

Integer

分发算法。

  • 1:加权轮询(wrr)

  • 2:加权最少连接(wleastconn)

  • 3:源地址哈希(source)

  • 4:URI哈希(uri)

缺省值:1

member_type

String

VPC通道的成员类型。

  • ip

  • ecs

缺省值:ecs

type

Integer

vpc通道类型,默认为服务器类型。

  • 2:服务器类型

  • 3:微服务类型

当vpc_channel_type字段为空时,负载通道类型由type字段控制:

当type不为3或microservice_info为空,VCP通道类型默认为服务器类型。

当type=3,microservice_info不为空,VPC通道类型为微服务类型。

修改负载通道时vpc通道类型不会修改,直接使用原有的vpc通道类型。

此字段待废弃,请使用vpc_channel_type字段指定负载通道类型。

缺省值:2

vpc_channel_type

String

vpc通道类型。

  • builtin:服务器类型

  • microservice: 微服务类型

  • reference:引用负载通道类型

当vpc_channel_type为空时,负载通道类型取决于type字段的取值。

当vpc_channel_type不为空,但type字段非空或不为0时,当vpc_channel_type的指定类型与type字段指定的类型冲突时会校验报错。

当vpc_channel_type不为空,且type字段为空或等于0时,直接使用vpc_channel_type字段的值指定负载通道类型。

修改负载通道时vpc通道类型不会修改,直接使用原有的vpc通道类型。

dict_code

String

VPC通道的字典编码

支持英文,数字,特殊字符(-_.)

暂不支持

最小长度:3

最大长度:64

create_time

String

VPC通道的创建时间

id

String

VPC通道的编号

status

Integer

VPC通道的状态。

  • 1:正常

  • 2:异常

member_groups

Array of MemberGroupInfo objects

后端云服务器组列表。

microservice_info

MicroServiceInfo object

微服务的响应对象

members

Array of VpcMemberInfo objects

后端实例列表。

vpc_health_config

VpcHealthConfigInfo object

健康检查详情。

表4 MemberGroupInfo

参数

参数类型

描述

member_group_name

String

VPC通道后端服务器组名称。支持汉字、英文、数字、下划线、中划线、点,且只能以英文和汉字开头,3-64字符。

说明:

中文字符必须为UTF-8或者unicode编码。

member_group_remark

String

VPC通道后端服务器组描述。

最大长度:255

member_group_weight

Integer

VPC通道后端服务器组权重值。

当前服务器组存在服务器且此权重值存在时,自动使用此权重值分配权重。

最小值:0

最大值:100

dict_code

String

VPC通道后端服务器组的字典编码

支持英文,数字,特殊字符(-_.)

暂不支持

最小长度:3

最大长度:64

microservice_version

String

VPC通道后端服务器组的版本,仅VPC通道类型为微服务时支持。

最大长度:64

microservice_port

Integer

VPC通道后端服务器组的端口号,仅VPC通道类型为微服务时支持。端口号为0时后端服务器组下的所有地址沿用原来负载端口继承逻辑。

最小值:0

最大值:65535

microservice_labels

Array of MicroserviceLabel objects

VPC通道后端服务器组的标签,仅VPC通道类型为微服务时支持。

reference_vpc_channel_id

String

引用的负载通道编号,仅VPC通道类型为引用类型(vpc_channel_type=reference)时支持。

最小长度:0

最大长度:64

member_group_id

String

VPC通道后端服务器组编号

create_time

String

VPC通道后端服务器组创建时间

update_time

String

VPC通道后端服务器组更新时间

表5 MicroserviceLabel

参数

参数类型

描述

label_name

String

标签名称。

以字母或者数字开头和结尾,由字母、数字、连接符('-')、下划线('_')、点号('.')组成且63个字符之内。

最小长度:1

最大长度:63

label_value

String

标签值。

以字母或者数字开头和结尾,由字母、数字、连接符('-')、下划线('_')、点号('.')组成且63个字符之内。

最小长度:1

最大长度:63

表6 MicroServiceInfo

参数

参数类型

描述

id

String

微服务编号

instance_id

String

实例编号

service_type

String

微服务类型:

  • CSE:CSE微服务注册中心

  • CCE:CCE云容器引擎(工作负载)

  • CCE_SERVICE: CCE云容器引擎(Service)

  • NACOS: nacos引擎,nacos_info必填

cse_info

MicroServiceInfoCSE object

CSE微服务详细信息

cce_info

MicroServiceInfoCCE object

CCE微服务工作负载信息

cce_service_info

MicroServiceInfoCCEService object

CCE微服务Service信息

nacos_info

MicroServiceInfoNacosBase object

nacos基础信息。

update_time

String

微服务更新时间

create_time

String

微服务创建时间

表7 MicroServiceInfoCSE

参数

参数类型

描述

engine_id

String

微服务引擎编号

最大长度:64

service_id

String

微服务编号

最大长度:64

engine_name

String

微服务引擎名称

service_name

String

微服务名称

register_address

String

注册中心地址

cse_app_id

String

微服务所属的应用

version

String

微服务的版本,已废弃,通过后端服务器组中的版本承载。

最大长度:64

表8 MicroServiceInfoCCE

参数

参数类型

描述

cluster_id

String

云容器引擎集群编号

最大长度:64

namespace

String

命名空间

最大长度:64

workload_type

String

工作负载类型

  • deployment:无状态负载

  • statefulset:有状态负载

  • daemonset:守护进程集

app_name

String

APP名称。支持汉字,英文,数字,点,中划线,下划线,且只能以英文和汉字开头,1-64字符。

说明:

中文字符必须为UTF-8或者unicode编码。

最小长度:1

最大长度:64

label_key

String

服务标识名。支持汉字、英文、数字、中划线、下划线、点、斜杠、中英文格式下的小括号和冒号,且只能以英文、汉字和数字开头,1-64个字符。

说明:

中文字符必须为UTF-8或者unicode编码。

最小长度:1

最大长度:64

label_value

String

服务标识值。支持汉字,英文,数字,点,中划线,下划线,且只能以英文和汉字开头,1-64字符。

说明:

中文字符必须为UTF-8或者unicode编码。

最小长度:1

最大长度:64

cluster_name

String

云容器引擎集群名称

表9 MicroServiceInfoCCEService

参数

参数类型

描述

cluster_id

String

云容器引擎集群编号

最大长度:64

namespace

String

命名空间。1-63字符。只能包含小写字母、数字,以及 '-',必须以字母开头,必须以字母数字结尾。

最小长度:1

最大长度:63

service_name

String

Service名称。支持汉字,英文,数字,点,中划线,下划线,且只能以英文和汉字开头,1-64字符。

说明:

中文字符必须为UTF-8或者unicode编码。

最小长度:1

最大长度:64

cluster_name

String

云容器引擎集群名称

表10 MicroServiceInfoNacosBase

参数

参数类型

描述

namespace

String

命名空间ID,当选择默认命名空间public时,此项为空。由字母、数字、连接符('-')、下划线('_')组成且64个字符之内。

最小长度:0

最大长度:64

cluster_name

String

集群名称,默认为DEFAULT。由字母、数字、连接符('-')、下划线('_')组成且64个字符之内。

最小长度:0

最大长度:64

group_name

String

分组名称,默认为DEFAULT_GROUP。由字母、数字、连接符('-')、下划线('_')、点号('.')、冒号(':')组成且128个字符之内。

最小长度:0

最大长度:128

service_name

String

微服务名称。不包含中文和@@,不得以@开头,512个字符以内。

最小长度:1

最大长度:512

server_config

Array of NacosServerConfig objects

nacos服务端配置信息。

数组长度:1 - 9

user_info

NacosUserInfo object

nacos用户信息。

表11 NacosServerConfig

参数

参数类型

描述

ip_address

String

nacos服务端IP地址。不包含中文字符。

最小长度:7

最大长度:128

port

Integer

nacos服务端端口号。取值范围1 ~ 65535。

最小值:1

最大值:65535

grpc_port

Integer

nacos服务端gRPC端口号,默认为port+1000。取值范围1 ~ 65535。

最小值:1

最大值:65535

表12 NacosUserInfo

参数

参数类型

描述

user_name

String

nacos用户名。

最小长度:1

最大长度:64

password

String

nacos密码。

最小长度:1

最大长度:64

表13 VpcMemberInfo

参数

参数类型

描述

host

String

后端服务器地址

后端实例类型为ip时必填

最大长度:255

weight

Integer

权重值。

允许您对后端服务进行评级,权重值越大,转发到该云服务的请求数量越多。

最小值:0

最大值:10000

is_backup

Boolean

是否备用节点。

开启后对应后端服务为备用节点,仅当非备用节点全部故障时工作。

实例需要升级到对应版本才支持此功能,如果不支持请联系技术支持。

缺省值:false

member_group_name

String

后端服务器组名称。为后端服务地址选择服务器组,便于统一修改对应服务器组的后端地址。

status

Integer

后端服务器状态

  • 1:可用

  • 2:不可用

port

Integer

后端服务器端口

最小值:0

最大值:65535

ecs_id

String

后端云服务器的编号。

后端实例类型为ecs时必填,支持英文,数字,“-”,“_”,1 ~ 64字符。

最大长度:255

ecs_name

String

后端云服务器的名称。

后端实例类型为ecs时必填,支持汉字,英文,数字,“-”,“_”,“.”,1 ~ 64字符。

最大长度:64

id

String

后端实例对象的编号

vpc_channel_id

String

VPC通道的编号

create_time

String

后端实例增加到VPC通道的时间

member_group_id

String

后端服务器组编号

health_status

String

负载通道后端实例健康状态,unknown、healthy、unhealthy分别标识未做健康检查、健康、不健康。

表14 VpcHealthConfigInfo

参数

参数类型

描述

protocol

String

使用以下协议,对VPC中主机执行健康检查:

  • TCP

  • HTTP

  • HTTPS

path

String

健康检查时的目标路径。protocol = http或https时必选

method

String

健康检查时的请求方法

缺省值:GET

port

Integer

健康检查的目标端口,缺少或port = 0时为VPC中主机的端口号。

如果此端口存在非0值,则使用此端口进行健康检查。

最小值:0

最大值:65535

threshold_normal

Integer

正常阈值。判定VPC通道中主机正常的依据为:连续检查x成功,x为您设置的正常阈值。

最小值:1

最大值:10

threshold_abnormal

Integer

异常阈值。判定VPC通道中主机异常的依据为:连续检查x失败,x为您设置的异常阈值。

最小值:1

最大值:10

time_interval

Integer

间隔时间:连续两次检查的间隔时间,单位为秒。必须大于timeout字段取值。

最小值:1

最大值:300

http_code

String

检查目标HTTP响应时,判断成功使用的HTTP响应码。取值范围为100到599之前的任意整数值,支持如下三种格式:

  • 多个值,如:200,201,202

  • 一系列值,如:200-299

  • 组合值,如:201,202,210-299

    protocol = http时必选

enable_client_ssl

Boolean

是否开启双向认证。如果开启,则使用实例配置中的backend_client_certificate配置项的证书

缺省值:false

status

Integer

健康检查状态

  • 1:可用

  • 2:不可用

timeout

Integer

超时时间:检查期间,无响应的时间,单位为秒。必须小于time_interval字段取值。

最小值:1

最大值:30

vpc_channel_id

String

VPC通道的编号

id

String

健康检查的编号

create_time

String

创建时间

状态码: 400

表15 响应Body参数

参数

参数类型

描述

error_code

String

错误码

error_msg

String

错误描述

状态码: 401

表16 响应Body参数

参数

参数类型

描述

error_code

String

错误码

error_msg

String

错误描述

状态码: 403

表17 响应Body参数

参数

参数类型

描述

error_code

String

错误码

error_msg

String

错误描述

状态码: 404

表18 响应Body参数

参数

参数类型

描述

error_code

String

错误码

error_msg

String

错误描述

状态码: 500

表19 响应Body参数

参数

参数类型

描述

error_code

String

错误码

error_msg

String

错误描述

请求示例

响应示例

状态码: 200

OK

  • 示例 1

    {
      "name" : "VPC_demo",
      "port" : 22,
      "balance_strategy" : 1,
      "member_type" : "ip",
      "dict_code" : "",
      "create_time" : "2020-07-23T07:11:57.244829604Z",
      "id" : "56a7d7358e1b42459c9d730d65b14e59",
      "status" : 1,
      "member_groups" : [ ],
      "type" : 2,
      "members" : [ {
        "host" : "192.168.0.5",
        "weight" : 1,
        "is_backup" : false,
        "member_group_name" : "",
        "status" : 1,
        "port" : 22,
        "ecs_id" : "192.168.0.5",
        "ecs_name" : "192.168.0.5",
        "id" : "be63c6260a1043888187f84af39c9f0e",
        "vpc_channel_id" : "56a7d7358e1b42459c9d730d65b14e59",
        "create_time" : "2020-07-23T07:11:57Z",
        "member_group_id" : "",
        "health_status" : "healthy"
      }, {
        "host" : "192.168.1.124",
        "weight" : 2,
        "is_backup" : false,
        "member_group_name" : "",
        "status" : 1,
        "port" : 22,
        "ecs_id" : "192.168.1.124",
        "ecs_name" : "192.168.1.124",
        "id" : "a57b13f1b89b417ca8acd76909e6df67",
        "vpc_channel_id" : "56a7d7358e1b42459c9d730d65b14e59",
        "create_time" : "2020-07-23T07:11:57Z",
        "member_group_id" : "",
        "health_status" : "unhealthy"
      } ],
      "vpc_health_config" : {
        "protocol" : "http",
        "path" : "/vpc/demo",
        "method" : "GET",
        "port" : 22,
        "threshold_normal" : 2,
        "threshold_abnormal" : 5,
        "time_interval" : 10,
        "http_code" : "200",
        "enable_client_ssl" : false,
        "status" : 1,
        "timeout" : 5,
        "vpc_channel_id" : "56a7d7358e1b42459c9d730d65b14e59",
        "id" : "3b3d02026c5f402d85e8645ea95b0816",
        "create_time" : "2020-07-23T07:11:57Z"
      },
      "microservice_info" : {
        "id" : "",
        "instance_id" : "",
        "service_type" : "",
        "cse_info" : {
          "cse_app_id" : "",
          "engine_id" : "",
          "engine_name" : "",
          "register_address" : "",
          "service_id" : "",
          "service_name" : ""
        },
        "cce_info" : {
          "cluster_id" : "",
          "cluster_name" : "",
          "namespace" : "",
          "workload_type" : "",
          "app_name" : ""
        },
        "create_time" : "",
        "update_time" : ""
      }
    }
  • 示例 2

    {
      "name" : "VPC_demo",
      "id" : "105c6902457144a4820dff8b1ad63331",
      "balance_strategy" : 1,
      "dict_code" : "",
      "create_time" : "2020-07-23T07:11:57.244829604Z",
      "member_type" : "ip",
      "port" : 22,
      "status" : 1,
      "member_groups" : [ {
        "member_group_id" : "c1ce135c705c4066853a0460b318fe16",
        "member_group_name" : "test",
        "member_group_weight" : 1,
        "member_group_remark" : "remark",
        "create_time" : "2020-07-23T07:11:57.244829604Z",
        "update_time" : "2020-07-23T07:11:57.244829604Z",
        "microservice_version" : "v1",
        "microservice_port" : 80
      }, {
        "member_group_id" : "c1ce135c705c4066853a0460b318fe17",
        "member_group_name" : "default",
        "member_group_weight" : 2,
        "member_group_remark" : "remark",
        "create_time" : "2020-07-23T07:11:57.244829604Z",
        "update_time" : "2020-07-23T07:11:57.244829604Z",
        "microservice_version" : "v2",
        "microservice_port" : 80
      } ],
      "type" : 3,
      "vpc_health_config" : {
        "protocol" : "http",
        "path" : "/vpc/demo",
        "method" : "GET",
        "port" : 22,
        "threshold_normal" : 2,
        "threshold_abnormal" : 5,
        "time_interval" : 10,
        "http_code" : "200",
        "enable_client_ssl" : false,
        "status" : 1,
        "timeout" : 5,
        "vpc_channel_id" : "56a7d7358e1b42459c9d730d65b14e59",
        "id" : "3b3d02026c5f402d85e8645ea95b0816",
        "create_time" : "2020-07-23T07:11:57Z"
      },
      "microservice_info" : {
        "id" : "9483afa235be45158a70c19ab817ac65",
        "instance_id" : "eddc4d25480b4cd6b512f270a1b8b341",
        "service_type" : "CCE",
        "cse_info" : {
          "cse_app_id" : "",
          "engine_id" : "",
          "engine_name" : "",
          "register_address" : "",
          "service_id" : "",
          "service_name" : ""
        },
        "cce_info" : {
          "cluster_id" : "ab1485b4f91b45abbcd560be591f7309",
          "cluster_name" : "cce-test",
          "namespace" : "default",
          "workload_type" : "deployment",
          "app_name" : "testapp"
        },
        "create_time" : "2020-07-23T07:11:57.244829604Z",
        "update_time" : "2020-07-23T07:11:57.244829604Z"
      }
    }

状态码: 400

Bad Request

{
  "error_code" : "APIG.2012",
  "error_msg" : "Invalid parameter value,parameterName:id. Please refer to the support documentation"
}

状态码: 401

Unauthorized

{
  "error_code" : "APIG.1002",
  "error_msg" : "Incorrect token or token resolution failed"
}

状态码: 403

Forbidden

{
  "error_code" : "APIG.1005",
  "error_msg" : "No permissions to request this method"
}

状态码: 404

Not Found

{
  "error_code" : "APIG.3023",
  "error_msg" : "The VPC channel does not exist,id:56a7d7358e1b42459c9d730d65b14e59"
}

状态码: 500

Internal Server Error

{
  "error_code" : "APIG.9999",
  "error_msg" : "System error"
}

状态码

状态码

描述

200

OK

400

Bad Request

401

Unauthorized

403

Forbidden

404

Not Found

500

Internal Server Error

错误码

请参见错误码

相关文档