文档首页/ 云连接 CC/ API参考/ API/ 中心网络管理/ 通过标签过滤中心网络实例
更新时间:2024-05-13 GMT+08:00

通过标签过滤中心网络实例

功能介绍

通过标签过滤中心网络实例。

调用方法

请参见如何调用API

URI

POST /v3/{domain_id}/gcn/central-networks/filter

表1 路径参数

参数

是否必选

参数类型

描述

domain_id

String

账户ID。

最小长度:10

最大长度:32

表2 Query参数

参数

是否必选

参数类型

描述

limit

Integer

每页返回的个数。 取值范围:1~1000。

最小值:1

最大值:1000

缺省值:1000

marker

String

翻页信息,从上次API调用返回的翻页数据中获取,可填写前一页marker或者后一页marker,填入前一页previous_marker就向前翻页,后一页next_marker就向翻页。 翻页过程中,查询条件不能修改,包括过滤条件,排序条件,limit。

最小长度:1

最大长度:4096

请求参数

表3 请求Header参数

参数

是否必选

参数类型

描述

X-Auth-Token

String

用户Token。

最小长度:0

最大长度:2000000

表4 请求Body参数

参数

是否必选

参数类型

描述

tags

Array of MultivaluedTag objects

包含标签。

数组长度:1 - 20

表5 MultivaluedTag

参数

是否必选

参数类型

描述

key

String

标签键,最大长度128个unicode字符,格式为大小写字母,数字,中划线“-”,下划线“_”,中文。

values

Array of strings

相同键的值列表

数组长度:1 - 20

响应参数

状态码: 200

表6 响应Body参数

参数

参数类型

描述

request_id

String

资源ID标识符。

最小长度:32

最大长度:36

page_info

PageInfo object

分页查询页的信息。

central_networks

Array of CentralNetwork objects

中心网络列表。

数组长度:0 - 2000

表7 PageInfo

参数

参数类型

描述

next_marker

String

向后分页标识符。

最小长度:1

最大长度:4096

previous_marker

String

向前分页标识符。

最小长度:1

最大长度:4096

current_count

Integer

当前列表中资源数量。

最小值:0

最大值:2000

表8 CentralNetwork

参数

参数类型

描述

id

String

资源ID标识符。

name

String

实例名字。

description

String

实例描述。不支持 <>。

最小长度:0

最大长度:255

created_at

String

实例创建时间。UTC时间格式,yyyy-MM-ddTHH:mm:ss。

updated_at

String

实例更新时间。UTC时间格式,yyyy-MM-ddTHH:mm:ss。

domain_id

String

实例所属账号ID。

state

String

中心网络状态。

  • AVAILABLE (可用)

  • UPDATING (处理中)

  • FAILED (失败)

  • CREATING (创建中)

  • DELETING (删除中)

  • DELETED (已刪除)

enterprise_project_id

String

实例所属企业项目ID。

最小长度:1

最大长度:36

tags

Array of Tag objects

实例标签。

数组长度:1 - 20

planes

Array of CentralNetworkPlane objects

中心网平面列表。

数组长度:0 - 2000

er_instances

Array of CentralNetworkErInstance objects

中心网ER实例列表。

数组长度:1 - 200

connections

Array of CentralNetworkConnectionInfo objects

中心网ER连接列表。

数组长度:0 - 2000

default_plane_id

String

资源ID标识符。

表9 Tag

参数

参数类型

描述

key

String

标签键,最大长度128个unicode字符,格式为大小写字母,数字,中划线“-”,下划线“_”,中文。

value

String

标签值,最大长度255个unicode字符,格式为大小写字母,数字,中划线“-”,下划线“_”,点“.”,中文。

表10 CentralNetworkPlane

参数

参数类型

描述

id

String

资源ID标识符。

name

String

实例名字。

associate_er_tables

Array of AssociateErTableDocument objects

关联的中心网络ER实例列表。

数组长度:0 - 100

exclude_er_connections

Array of ExcludeErConnectionDocument objects

当自动连接所有ER实例时,排除中心网络的ER实例的连接。

数组长度:0 - 100

表11 AssociateErTableDocument

参数

参数类型

描述

project_id

String

实例所属项目ID。

region_id

String

RegionID。

enterprise_router_id

String

企业路由器的ID。

enterprise_router_table_id

String

资源ID标识符。

表12 ExcludeErConnectionDocument

参数

参数类型

描述

[数组元素]

Array of AssociateErInstanceDocument objects

中心网络平面管理的ER连接

表13 AssociateErInstanceDocument

参数

参数类型

描述

enterprise_router_id

String

企业路由器的ID。

project_id

String

实例所属项目ID。

region_id

String

RegionID。

表14 CentralNetworkErInstance

参数

参数类型

描述

id

String

资源ID标识符。

enterprise_router_id

String

企业路由器的ID。

project_id

String

实例所属项目ID。

region_id

String

RegionID。

asn

Long

网络实例BGP协议的AS号。

最小值:0

最大值:4294967295

site_code

String

站点编码定义

表15 CentralNetworkConnectionInfo

参数

参数类型

描述

id

String

资源ID标识符。

plane_id

String

资源ID标识符。

global_connection_bandwidth_id

String

全域互联带宽ID。

bandwidth_size

Integer

带宽值定义,单位Mbps。

connection_type

String

中心网络连接类型定义:

  • ER-ER (ER-ER Connection)

  • ER-GDGW (ER-GDGW Attachment Connection)

  • ER-ER_ROUTE_TABLE (ER-ER_ROUTE_TABLE Attachment Connection)

connection_point_pair

Array of ConnectionPoint objects

中心网络连接的两个端点定义,长度固定为2的数组。

数组长度:2 - 2

state

String

中心网络连接状态。

  • AVAILABLE (可用)

  • CREATING (创建中)

  • UPDATING (更新中)

  • DELETING (删除中)

  • FREEZING (冻结中)

  • UNFREEZING (解冻中)

  • RECOVERING (恢复中)

  • FAILED (失败)

  • DELETED (已刪除)

  • APPROVING (审批中)

  • APPROVED (已审批)

  • UNAPPROVED (审批未通过)

表16 ConnectionPoint

参数

参数类型

描述

id

String

资源ID标识符。

project_id

String

实例所属项目ID。

region_id

String

RegionID。

site_code

String

站点编码定义

instance_id

String

资源ID标识符。

type

String

中心网络连接点类型定义:

  • ER (EnterpriseRouter)

  • GDGW (Global DC Gateway)

  • ER_ROUTE_TABLE (Route Table)

请求示例

通过标签过滤中心网络实例

POST https://{cc_endpoint}/v3/{domain_id}/gcn/central-networks/filter

{
  "tags" : [ {
    "key" : "key",
    "values" : [ "value" ]
  } ]
}

响应示例

状态码: 200

通过标签过滤中心网络实例成功。

{
  "request_id" : "0b6ba65808f9d7277f916d44845d271c",
  "page_info" : {
    "current_count" : 1
  },
  "central_networks" : [ {
    "id" : "e096c86f-817c-418c-945c-6b1d8860a15d",
    "name" : "name",
    "created_at" : "2023-10-09T06:22:40.856Z",
    "updated_at" : "2023-10-09T06:22:40.856Z",
    "domain_id" : "XXX",
    "state" : "AVAILABLE",
    "enterprise_project_id" : "0"
  } ]
}

SDK代码示例

SDK代码示例如下。

通过标签过滤中心网络实例

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
package com.huaweicloud.sdk.test;

import com.huaweicloud.sdk.core.auth.ICredential;
import com.huaweicloud.sdk.core.auth.GlobalCredentials;
import com.huaweicloud.sdk.core.exception.ConnectionException;
import com.huaweicloud.sdk.core.exception.RequestTimeoutException;
import com.huaweicloud.sdk.core.exception.ServiceResponseException;
import com.huaweicloud.sdk.cc.v3.region.CcRegion;
import com.huaweicloud.sdk.cc.v3.*;
import com.huaweicloud.sdk.cc.v3.model.*;

import java.util.List;
import java.util.ArrayList;

public class ListCentralNetworksByTagsSolution {

    public static void main(String[] args) {
        // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
        // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
        String ak = System.getenv("CLOUD_SDK_AK");
        String sk = System.getenv("CLOUD_SDK_SK");

        ICredential auth = new GlobalCredentials()
                .withAk(ak)
                .withSk(sk);

        CcClient client = CcClient.newBuilder()
                .withCredential(auth)
                .withRegion(CcRegion.valueOf("<YOUR REGION>"))
                .build();
        ListCentralNetworksByTagsRequest request = new ListCentralNetworksByTagsRequest();
        request.withLimit(<limit>);
        request.withMarker("<marker>");
        ListCentralNetworksByTagsRequestBody body = new ListCentralNetworksByTagsRequestBody();
        List<String> listTagsValues = new ArrayList<>();
        listTagsValues.add("value");
        List<MultivaluedTag> listbodyTags = new ArrayList<>();
        listbodyTags.add(
            new MultivaluedTag()
                .withKey("key")
                .withValues(listTagsValues)
        );
        body.withTags(listbodyTags);
        request.withBody(body);
        try {
            ListCentralNetworksByTagsResponse response = client.listCentralNetworksByTags(request);
            System.out.println(response.toString());
        } catch (ConnectionException e) {
            e.printStackTrace();
        } catch (RequestTimeoutException e) {
            e.printStackTrace();
        } catch (ServiceResponseException e) {
            e.printStackTrace();
            System.out.println(e.getHttpStatusCode());
            System.out.println(e.getRequestId());
            System.out.println(e.getErrorCode());
            System.out.println(e.getErrorMsg());
        }
    }
}

通过标签过滤中心网络实例

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
# coding: utf-8

from huaweicloudsdkcore.auth.credentials import GlobalCredentials
from huaweicloudsdkcc.v3.region.cc_region import CcRegion
from huaweicloudsdkcore.exceptions import exceptions
from huaweicloudsdkcc.v3 import *

if __name__ == "__main__":
    # The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
    # In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
    ak = __import__('os').getenv("CLOUD_SDK_AK")
    sk = __import__('os').getenv("CLOUD_SDK_SK")

    credentials = GlobalCredentials(ak, sk) \

    client = CcClient.new_builder() \
        .with_credentials(credentials) \
        .with_region(CcRegion.value_of("<YOUR REGION>")) \
        .build()

    try:
        request = ListCentralNetworksByTagsRequest()
        request.limit = <limit>
        request.marker = "<marker>"
        listValuesTags = [
            "value"
        ]
        listTagsbody = [
            MultivaluedTag(
                key="key",
                values=listValuesTags
            )
        ]
        request.body = ListCentralNetworksByTagsRequestBody(
            tags=listTagsbody
        )
        response = client.list_central_networks_by_tags(request)
        print(response)
    except exceptions.ClientRequestException as e:
        print(e.status_code)
        print(e.request_id)
        print(e.error_code)
        print(e.error_msg)

通过标签过滤中心网络实例

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
package main

import (
	"fmt"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/global"
    cc "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/cc/v3"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/cc/v3/model"
    region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/cc/v3/region"
)

func main() {
    // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
    // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
    ak := os.Getenv("CLOUD_SDK_AK")
    sk := os.Getenv("CLOUD_SDK_SK")

    auth := global.NewCredentialsBuilder().
        WithAk(ak).
        WithSk(sk).
        Build()

    client := cc.NewCcClient(
        cc.CcClientBuilder().
            WithRegion(region.ValueOf("<YOUR REGION>")).
            WithCredential(auth).
            Build())

    request := &model.ListCentralNetworksByTagsRequest{}
	limitRequest:= int32(<limit>)
	request.Limit = &limitRequest
	markerRequest:= "<marker>"
	request.Marker = &markerRequest
	var listValuesTags = []string{
        "value",
    }
	var listTagsbody = []model.MultivaluedTag{
        {
            Key: "key",
            Values: listValuesTags,
        },
    }
	request.Body = &model.ListCentralNetworksByTagsRequestBody{
		Tags: listTagsbody,
	}
	response, err := client.ListCentralNetworksByTags(request)
	if err == nil {
        fmt.Printf("%+v\n", response)
    } else {
        fmt.Println(err)
    }
}

更多编程语言的SDK代码示例,请参见API Explorer的代码示例页签,可生成自动对应的SDK代码示例。

状态码

状态码

描述

200

通过标签过滤中心网络实例成功。

错误码

请参见错误码