文档首页/ 云专线 DC/ API参考/ API/ 物理连接/ 创建托管专线连接
更新时间:2024-10-21 GMT+08:00

创建托管专线连接

功能介绍

用于合作伙伴用户最终租户创建托管专线 创建者必须拥有合作伙伴资质,并且已经构建好运营(hosting)专线

调用方法

请参见如何调用API

URI

POST /v3/{project_id}/dcaas/hosted-connects

表1 路径参数

参数

是否必选

参数类型

描述

project_id

String

租户项目ID

请求参数

表2 请求Header参数

参数

是否必选

参数类型

描述

X-Auth-Token

String

用户Token。 获取Token,请参考《统一身份认证服务API参考》的“获取用户Token”章节。请求响应成功后在响应消息头中包含的“X-Subject-Token”的值即为Token值。

最小长度:0

最大长度:10240

表3 请求Body参数

参数

是否必选

参数类型

描述

hosted_connect

CreateHostedDirectConnect object

创建托管专线参数对象

表4 CreateHostedDirectConnect

参数

是否必选

参数类型

描述

name

String

托管物理专线的名字。

最小长度:0

最大长度:64

description

String

托管专线的描述信息

最小长度:0

最大长度:128

bandwidth

Integer

指定托管专线接入带宽,单位Mbps

最小值:2

最大值:400000

hosting_id

String

hosted物理专线对应的hosting物理专线的ID

vlan

Integer

指定托管(hosted)专线预分配的vlan

最小值:0

最大值:3999

resource_tenant_id

String

为其他租户创建托管专线,指定对应的租户ID

最小长度:0

最大长度:32

peer_location

String

物理专线对端所在的物理位置,省/市/街道或IDC名字。

最小长度:0

最大长度:255

响应参数

状态码: 201

表5 响应Body参数

参数

参数类型

描述

request_id

String

操作请求ID

hosted_connect

HostedDirectConnect object

托管专线对象信息

表6 HostedDirectConnect

参数

参数类型

描述

id

String

托管专线ID

最小长度:36

最大长度:36

tenant_id

String

实例所属项目ID。

name

String

物理专线名字

最小长度:0

最大长度:64

description

String

物理专线的描述信息

最小长度:0

最大长度:128

bandwidth

Integer

物理专线接入带宽,单位Mbps。

最小值:2

最大值:400000

location

String

专线的接入位置信息

最小长度:0

最大长度:255

peer_location

String

物理专线对端所在的物理位置,省/市/街道或IDC名字。

最小长度:0

最大长度:255

hosting_id

String

hosted物理专线对应的hosting物理专线的ID

provider

String

专线线路的提供商

admin_state_up

Boolean

管理状态:true或false

缺省值:true

vlan

Integer

hosted物理专线预分配的vlan。

最小值:0

最大值:3999

status

String

操作状态,合法值是: BUILD:已开通 ACTIVE:物理连接正常 DOWN:专线对应的端口处于down的状态,可能存在线路故障等异常。 ERROR:专线配置异常 PENDING_DELETE:删除中 PENDING_UPDATE:更新中 PENDING_CREATE:创建中

枚举值:

  • BUILD
  • ACTIVE
  • DOWN
  • ERROR
  • PENDING_DELETE
  • PENDING_UPDATE
  • PENDING_CREATE

apply_time

String

物理专线申请时间。采用UTC时间格式,格式为:yyyy-MM-ddTHH:mm:ss.SSSZ

create_time

String

物理专线创建时间。采用UTC时间格式,格式为:yyyy-MM-ddTHH:mm:ss.SSSZ

provider_status

String

物理专线的运营商操作状态,合法值是:ACTIVE, DOWN

枚举值:

  • ACTIVE
  • DOWN

port_type

String

物理专线接入接口的类型,支持1G 10G 40G 100G

枚举值:

  • 1G
  • 10G
  • 40G
  • 100G

type

String

物理专线的类型,类型为托管专线(hosted)。

缺省值:hosted

请求示例

创建一个托管物理连接,设置带宽为10,VLAN为441。

POST https://{dc_endpoint}/v3/6fbe9263116a4b68818cf1edce16bc4f/dcaas/hosted-connects

{
  "hosted_connect" : {
    "name" : "client-dc-faf1",
    "description" : "Hosted Connect",
    "resource_tenant_id" : "0605768a3300d5762f82c01180692873",
    "hosting_id" : "2cfb53be-b05f-40d5-a2f8-3a59ac383836",
    "vlan" : 441,
    "bandwidth" : 10
  }
}

响应示例

状态码: 201

Created

  • 成功创建托管专线连接
    {
      "hosted_connect" : {
        "id" : "0278b472-ffa5-4eb3-8c0d-979d479f8ef6",
        "name" : "client-dc-faf1",
        "description" : "Hosted Connect",
        "tenant_id" : "0605768a3300d5762f82c01180692873",
        "hosting_id" : "2cfb53be-b05f-40d5-a2f8-3a59ac383836",
        "vlan" : 441,
        "bandwidth" : 10,
        "location" : "ExampleLocation",
        "peer_location" : "",
        "provider" : "ExampleProvider",
        "type" : "hosted",
        "port_type" : "10G",
        "provider_status" : "ACTIVE",
        "status" : "ACTIVE",
        "apply_time" : "2022-07-13T08:25:38.000Z",
        "admin_state_up" : true,
        "create_time" : "2022-07-13T08:25:38.000Z"
      },
      "request_id" : "a59a3776faa1d055f8124dc7b0977a90"
    }

SDK代码示例

SDK代码示例如下。

创建一个托管物理连接,设置带宽为10,VLAN为441。

 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 com.huaweicloud.sdk.test;

import com.huaweicloud.sdk.core.auth.ICredential;
import com.huaweicloud.sdk.core.auth.BasicCredentials;
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.dc.v3.region.DcRegion;
import com.huaweicloud.sdk.dc.v3.*;
import com.huaweicloud.sdk.dc.v3.model.*;


public class CreateHostedDirectConnectSolution {

    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 BasicCredentials()
                .withAk(ak)
                .withSk(sk);

        DcClient client = DcClient.newBuilder()
                .withCredential(auth)
                .withRegion(DcRegion.valueOf("<YOUR REGION>"))
                .build();
        CreateHostedDirectConnectRequest request = new CreateHostedDirectConnectRequest();
        CreateHostedDirectConnectRequestBody body = new CreateHostedDirectConnectRequestBody();
        CreateHostedDirectConnect hostedConnectbody = new CreateHostedDirectConnect();
        hostedConnectbody.withName("client-dc-faf1")
            .withDescription("Hosted Connect")
            .withBandwidth(10)
            .withHostingId("2cfb53be-b05f-40d5-a2f8-3a59ac383836")
            .withVlan(441)
            .withResourceTenantId("0605768a3300d5762f82c01180692873");
        body.withHostedConnect(hostedConnectbody);
        request.withBody(body);
        try {
            CreateHostedDirectConnectResponse response = client.createHostedDirectConnect(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());
        }
    }
}

创建一个托管物理连接,设置带宽为10,VLAN为441。

 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
# coding: utf-8

from huaweicloudsdkcore.auth.credentials import BasicCredentials
from huaweicloudsdkdc.v3.region.dc_region import DcRegion
from huaweicloudsdkcore.exceptions import exceptions
from huaweicloudsdkdc.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 = os.getenv("CLOUD_SDK_AK")
    sk = os.getenv("CLOUD_SDK_SK")

    credentials = BasicCredentials(ak, sk) \

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

    try:
        request = CreateHostedDirectConnectRequest()
        hostedConnectbody = CreateHostedDirectConnect(
            name="client-dc-faf1",
            description="Hosted Connect",
            bandwidth=10,
            hosting_id="2cfb53be-b05f-40d5-a2f8-3a59ac383836",
            vlan=441,
            resource_tenant_id="0605768a3300d5762f82c01180692873"
        )
        request.body = CreateHostedDirectConnectRequestBody(
            hosted_connect=hostedConnectbody
        )
        response = client.create_hosted_direct_connect(request)
        print(response)
    except exceptions.ClientRequestException as e:
        print(e.status_code)
        print(e.request_id)
        print(e.error_code)
        print(e.error_msg)

创建一个托管物理连接,设置带宽为10,VLAN为441。

 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
package main

import (
	"fmt"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/basic"
    dc "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/dc/v3"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/dc/v3/model"
    region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/dc/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 := basic.NewCredentialsBuilder().
        WithAk(ak).
        WithSk(sk).
        Build()

    client := dc.NewDcClient(
        dc.DcClientBuilder().
            WithRegion(region.ValueOf("<YOUR REGION>")).
            WithCredential(auth).
            Build())

    request := &model.CreateHostedDirectConnectRequest{}
	nameHostedConnect:= "client-dc-faf1"
	descriptionHostedConnect:= "Hosted Connect"
	hostedConnectbody := &model.CreateHostedDirectConnect{
		Name: &nameHostedConnect,
		Description: &descriptionHostedConnect,
		Bandwidth: int32(10),
		HostingId: "2cfb53be-b05f-40d5-a2f8-3a59ac383836",
		Vlan: int32(441),
		ResourceTenantId: "0605768a3300d5762f82c01180692873",
	}
	request.Body = &model.CreateHostedDirectConnectRequestBody{
		HostedConnect: hostedConnectbody,
	}
	response, err := client.CreateHostedDirectConnect(request)
	if err == nil {
        fmt.Printf("%+v\n", response)
    } else {
        fmt.Println(err)
    }
}

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

状态码

状态码

描述

201

Created

错误码

请参见错误码