文档首页/ 云连接 CC/ API参考/ API/ 中心网络管理/ 创建一个新版本的中心网络策略
更新时间:2024-05-13 GMT+08:00

创建一个新版本的中心网络策略

功能介绍

创建一份只读的中心网络的策略。如果您有策略文档内容改动,需要基于此版本重新创建一个新版本的策略。

调用方法

请参见如何调用API

URI

POST /v3/{domain_id}/gcn/central-network/{central_network_id}/policies

表1 路径参数

参数

是否必选

参数类型

描述

domain_id

String

账户ID。

最小长度:10

最大长度:32

central_network_id

String

中心网络的ID。

最小长度:36

最大长度:36

请求参数

表2 请求Header参数

参数

是否必选

参数类型

描述

X-Auth-Token

String

用户Token。

最小长度:0

最大长度:2000000

表3 请求Body参数

参数

是否必选

参数类型

描述

central_network_policy_document

CentralNetworkPolicyDocument object

中心网络策略文档。

表4 CentralNetworkPolicyDocument

参数

是否必选

参数类型

描述

default_plane

String

中心网络默认平面的名字。

缺省值:default-plane

最小长度:1

最大长度:64

planes

Array of CentralNetworkPlaneDocument objects

中心网络平面列表。

数组长度:1 - 100

er_instances

Array of AssociateErInstanceDocument objects

中心网络ER实例列表。

数组长度:1 - 200

表5 CentralNetworkPlaneDocument

参数

是否必选

参数类型

描述

name

String

实例名字。

associate_er_tables

Array of AssociateErTableDocument objects

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

数组长度:0 - 100

exclude_er_connections

Array of ExcludeErConnectionDocument objects

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

数组长度:0 - 100

表6 AssociateErTableDocument

参数

是否必选

参数类型

描述

project_id

String

实例所属项目ID。

region_id

String

RegionID。

enterprise_router_id

String

企业路由器的ID。

enterprise_router_table_id

String

资源ID标识符。

表7 ExcludeErConnectionDocument

参数

是否必选

参数类型

描述

[数组元素]

Array of AssociateErInstanceDocument objects

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

表8 AssociateErInstanceDocument

参数

是否必选

参数类型

描述

enterprise_router_id

String

企业路由器的ID。

project_id

String

实例所属项目ID。

region_id

String

RegionID。

响应参数

状态码: 201

表9 响应Body参数

参数

参数类型

描述

request_id

String

资源ID标识符。

最小长度:32

最大长度:36

central_network_policy

CentralNetworkPolicy object

中心网络策略详情。

表10 CentralNetworkPolicy

参数

参数类型

描述

id

String

资源ID标识符。

created_at

String

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

domain_id

String

实例所属账号ID。

state

String

中心网络策略状态。

  • AVAILABLE (可用)

  • CANCELING (取消中)

  • APPLYING (应用中)

  • FAILED (失败)

  • DELETED (已刪除)

central_network_id

String

中心网络ID。

document_template_version

String

文档模板版本。

  • 2022.08.30 (2022.08.30)

is_applied

Boolean

是否被应用。

version

Integer

中心网络策略的版本。

最小值:1

最大值:4096

document

CentralNetworkPolicyDocument object

中心网络策略文档。

表11 CentralNetworkPolicyDocument

参数

参数类型

描述

default_plane

String

中心网络默认平面的名字。

缺省值:default-plane

最小长度:1

最大长度:64

planes

Array of CentralNetworkPlaneDocument objects

中心网络平面列表。

数组长度:1 - 100

er_instances

Array of AssociateErInstanceDocument objects

中心网络ER实例列表。

数组长度:1 - 200

表12 CentralNetworkPlaneDocument

参数

参数类型

描述

name

String

实例名字。

associate_er_tables

Array of AssociateErTableDocument objects

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

数组长度:0 - 100

exclude_er_connections

Array of ExcludeErConnectionDocument objects

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

数组长度:0 - 100

表13 AssociateErTableDocument

参数

参数类型

描述

project_id

String

实例所属项目ID。

region_id

String

RegionID。

enterprise_router_id

String

企业路由器的ID。

enterprise_router_table_id

String

资源ID标识符。

表14 ExcludeErConnectionDocument

参数

参数类型

描述

[数组元素]

Array of AssociateErInstanceDocument objects

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

表15 AssociateErInstanceDocument

参数

参数类型

描述

enterprise_router_id

String

企业路由器的ID。

project_id

String

实例所属项目ID。

region_id

String

RegionID。

请求示例

创建中心网络策略

POST /v3/{domain_id}/gcn/central-network/{central_network_id}/policies

{
  "central_network_policy_document" : {
    "default_plane" : "default-plane",
    "planes" : [ {
      "name" : "default-plane"
    } ],
    "er_instances" : [ {
      "enterprise_router_id" : "395b0884-aab4-4bf0-8cb8-7f2da26708dd",
      "project_id" : "XXX",
      "region_id" : "cn-north-4"
    } ]
  }
}

响应示例

状态码: 201

创建中心网络策略成功。

{
  "request_id" : "76bfd2b0d492d0e479fbbd3981869c12",
  "central_network_policy" : {
    "id" : "f03478aa-3975-4ca7-9fb2-b49428a01636",
    "created_at" : "2023-10-09T06:22:40.857Z",
    "domain_id" : "XXX",
    "state" : "AVAILABLE",
    "central_network_id" : "e096c86f-817c-418c-945c-6b1d8860a15d",
    "document_template_version" : "2022.08.30",
    "is_applied" : true,
    "version" : 1,
    "document" : {
      "default_plane" : "default-plane",
      "planes" : [ {
        "name" : "default-plane",
        "associate_er_tables" : [ {
          "project_id" : "XXX",
          "region_id" : "cn-north-4",
          "enterprise_router_id" : "395b0884-aab4-4bf0-8cb8-7f2da26708dd",
          "enterprise_router_table_id" : "cc542128-5c2d-402a-8960-53bb2ed9484e"
        } ]
      } ],
      "er_instances" : [ {
        "enterprise_router_id" : "395b0884-aab4-4bf0-8cb8-7f2da26708dd",
        "project_id" : "XXX",
        "region_id" : "cn-north-4"
      } ]
    }
  }
}

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
61
62
63
64
65
66
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 CreateCentralNetworkPolicySolution {

    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();
        CreateCentralNetworkPolicyRequest request = new CreateCentralNetworkPolicyRequest();
        CreateCentralNetworkPolicyRequestBody body = new CreateCentralNetworkPolicyRequestBody();
        List<AssociateErInstanceDocument> listCentralNetworkPolicyDocumentErInstances = new ArrayList<>();
        listCentralNetworkPolicyDocumentErInstances.add(
            new AssociateErInstanceDocument()
                .withEnterpriseRouterId("395b0884-aab4-4bf0-8cb8-7f2da26708dd")
                .withRegionId("cn-north-4")
                .withProjectId("XXX")
        );
        List<CentralNetworkPlaneDocument> listCentralNetworkPolicyDocumentPlanes = new ArrayList<>();
        listCentralNetworkPolicyDocumentPlanes.add(
            new CentralNetworkPlaneDocument()
                .withName("default-plane")
        );
        CentralNetworkPolicyDocument centralNetworkPolicyDocumentbody = new CentralNetworkPolicyDocument();
        centralNetworkPolicyDocumentbody.withDefaultPlane("default-plane")
            .withPlanes(listCentralNetworkPolicyDocumentPlanes)
            .withErInstances(listCentralNetworkPolicyDocumentErInstances);
        body.withCentralNetworkPolicyDocument(centralNetworkPolicyDocumentbody);
        request.withBody(body);
        try {
            CreateCentralNetworkPolicyResponse response = client.createCentralNetworkPolicy(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
44
45
46
47
48
49
# 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 = CreateCentralNetworkPolicyRequest()
        listErInstancesCentralNetworkPolicyDocument = [
            AssociateErInstanceDocument(
                enterprise_router_id="395b0884-aab4-4bf0-8cb8-7f2da26708dd",
                region_id="cn-north-4",
                project_id="XXX"
            )
        ]
        listPlanesCentralNetworkPolicyDocument = [
            CentralNetworkPlaneDocument(
                name="default-plane"
            )
        ]
        centralNetworkPolicyDocumentbody = CentralNetworkPolicyDocument(
            default_plane="default-plane",
            planes=listPlanesCentralNetworkPolicyDocument,
            er_instances=listErInstancesCentralNetworkPolicyDocument
        )
        request.body = CreateCentralNetworkPolicyRequestBody(
            central_network_policy_document=centralNetworkPolicyDocumentbody
        )
        response = client.create_central_network_policy(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
52
53
54
55
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.CreateCentralNetworkPolicyRequest{}
	var listErInstancesCentralNetworkPolicyDocument = []model.AssociateErInstanceDocument{
        {
            EnterpriseRouterId: "395b0884-aab4-4bf0-8cb8-7f2da26708dd",
            RegionId: "cn-north-4",
            ProjectId: "XXX",
        },
    }
	var listPlanesCentralNetworkPolicyDocument = []model.CentralNetworkPlaneDocument{
        {
            Name: "default-plane",
        },
    }
	centralNetworkPolicyDocumentbody := &model.CentralNetworkPolicyDocument{
		DefaultPlane: "default-plane",
		Planes: listPlanesCentralNetworkPolicyDocument,
		ErInstances: &listErInstancesCentralNetworkPolicyDocument,
	}
	request.Body = &model.CreateCentralNetworkPolicyRequestBody{
		CentralNetworkPolicyDocument: centralNetworkPolicyDocumentbody,
	}
	response, err := client.CreateCentralNetworkPolicy(request)
	if err == nil {
        fmt.Printf("%+v\n", response)
    } else {
        fmt.Println(err)
    }
}

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

状态码

状态码

描述

201

创建中心网络策略成功。

错误码

请参见错误码