更新时间:2024-04-17 GMT+08:00

批量更新带宽

功能介绍

批量更新带宽,共享带宽和包周期带宽该接口不适用。

URI

PUT /v2/{project_id}/batch-bandwidths/modify

表1 路径参数

参数

是否必选

参数类型

描述

project_id

String

项目ID

请求参数

表2 请求Body参数

参数

是否必选

参数类型

描述

bandwidths

Array of ModifyBandwidthOption objects

更新带宽列表

表3 ModifyBandwidthOption

参数

是否必选

参数类型

描述

id

String

  • 功能说明:带宽唯一标识

最大长度:36

name

String

取值范围:1-64,支持数字、字母、中文、_(下划线)、-(中划线),为空表示不修改名称 功能说明:带宽名称 约束:name、size必须有一个参数有值

最小长度:1

最大长度:64

size

Integer

取值范围:默认1Mbit/s~2000Mbit/s(具体范围以各区域配置为准,请参见控制台对应页面显示),不带此参数时表示不修改大小 功能说明:带宽大小,单位Mbit/s。 约束:name、size必须有一个参数有值 如果传入的参数为小数(如 10.2)或者字符类型(如“10”),会自动强制转换为整数。 约束:name、size必须要有一个参数有值。 调整带宽时的最小单位会根据带宽范围不同存在差异: 小于等于300Mbit/s:默认最小单位为1Mbit/s。 300Mbit/s~1000Mbit/s:默认最小单位为50Mbit/s。 大于1000Mbit/s:默认最小单位为500Mbit/s。

charge_mode

String

功能说明:按流量计费,按带宽计费还是按增强型95计费。 取值范围:bandwidth,traffic,95peak_plus(按增强型95计费)不返回或者为空时表示是bandwidth。 约束:只有共享带宽支持95peak_plus(按增强型95计费),按增强型95计费时需要指定保底百分比,默认是20%。

枚举值:

  • bandwidth
  • traffic
  • 95peak_plus

响应参数

状态码: 200

表4 响应Body参数

参数

参数类型

描述

success_resources

Array of SuccessResources objects

成功资源

failure_resources

Array of FailureResources objects

失败资源

表5 SuccessResources

参数

参数类型

描述

id

String

  • 功能说明:更新成功的带宽id

最小长度:1

最大长度:36

表6 FailureResources

参数

参数类型

描述

id

String

  • 功能说明:更新失败的带宽id

最小长度:1

最大长度:36

code

String

  • 功能说明:错误码

最小长度:1

最大长度:36

message

String

  • 功能说明:错误信息

最小长度:1

最大长度:256

请求示例

批量更新带宽

{
  "bandwidths" : [ {
    "id" : "837d84a0-b940-4401-9477-4a99de1979a7",
    "name" : "bandwidth123",
    "size" : 5
  }, {
    "id" : "f2549bed-c419-4f58-9609-7ade104772bb",
    "name" : "bandwidth123",
    "size" : 5
  } ]
}

响应示例

状态码: 200

GET和PUT操作正常返回

{
  "success_resources" : [ {
    "id" : "837d84a0-b940-4401-9477-4a99de1979a7"
  } ],
  "failure_resources" : [ {
    "id" : "f2549bed-c419-4f58-9609-7ade104772bb",
    "code" : "VPC.0319",
    "message" : "updateBandwidth bandwidth failed. the bandwidth is share bandwidth."
  } ]
}

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
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.eip.v2.region.EipRegion;
import com.huaweicloud.sdk.eip.v2.*;
import com.huaweicloud.sdk.eip.v2.model.*;

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

public class BatchModifyBandwidthSolution {

    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);

        EipClient client = EipClient.newBuilder()
                .withCredential(auth)
                .withRegion(EipRegion.valueOf("<YOUR REGION>"))
                .build();
        BatchModifyBandwidthRequest request = new BatchModifyBandwidthRequest();
        ModifyBandwidthRequestBody body = new ModifyBandwidthRequestBody();
        List<ModifyBandwidthOption> listbodyBandwidths = new ArrayList<>();
        listbodyBandwidths.add(
            new ModifyBandwidthOption()
                .withId("837d84a0-b940-4401-9477-4a99de1979a7")
                .withName("bandwidth123")
                .withSize(5)
        );
        listbodyBandwidths.add(
            new ModifyBandwidthOption()
                .withId("f2549bed-c419-4f58-9609-7ade104772bb")
                .withName("bandwidth123")
                .withSize(5)
        );
        body.withBandwidths(listbodyBandwidths);
        request.withBody(body);
        try {
            BatchModifyBandwidthResponse response = client.batchModifyBandwidth(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
# coding: utf-8

from huaweicloudsdkcore.auth.credentials import BasicCredentials
from huaweicloudsdkeip.v2.region.eip_region import EipRegion
from huaweicloudsdkcore.exceptions import exceptions
from huaweicloudsdkeip.v2 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 = BasicCredentials(ak, sk) \

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

    try:
        request = BatchModifyBandwidthRequest()
        listBandwidthsbody = [
            ModifyBandwidthOption(
                id="837d84a0-b940-4401-9477-4a99de1979a7",
                name="bandwidth123",
                size=5
            ),
            ModifyBandwidthOption(
                id="f2549bed-c419-4f58-9609-7ade104772bb",
                name="bandwidth123",
                size=5
            )
        ]
        request.body = ModifyBandwidthRequestBody(
            bandwidths=listBandwidthsbody
        )
        response = client.batch_modify_bandwidth(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
package main

import (
	"fmt"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/basic"
    eip "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/eip/v2"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/eip/v2/model"
    region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/eip/v2/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 := eip.NewEipClient(
        eip.EipClientBuilder().
            WithRegion(region.ValueOf("<YOUR REGION>")).
            WithCredential(auth).
            Build())

    request := &model.BatchModifyBandwidthRequest{}
	nameBandwidths:= "bandwidth123"
	sizeBandwidths:= int32(5)
	nameBandwidths1:= "bandwidth123"
	sizeBandwidths1:= int32(5)
	var listBandwidthsbody = []model.ModifyBandwidthOption{
        {
            Id: "837d84a0-b940-4401-9477-4a99de1979a7",
            Name: &nameBandwidths,
            Size: &sizeBandwidths,
        },
        {
            Id: "f2549bed-c419-4f58-9609-7ade104772bb",
            Name: &nameBandwidths1,
            Size: &sizeBandwidths1,
        },
    }
	request.Body = &model.ModifyBandwidthRequestBody{
		Bandwidths: listBandwidthsbody,
	}
	response, err := client.BatchModifyBandwidth(request)
	if err == nil {
        fmt.Printf("%+v\n", response)
    } else {
        fmt.Println(err)
    }
}

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

状态码

状态码

描述

200

GET和PUT操作正常返回

错误码

请参见错误码