文档首页/ 弹性公网IP EIP/ API参考/ API/ 批量操作弹性公网IP/ 批量解绑弹性公网IP - BatchDisassociatePublicips
更新时间:2025-12-31 GMT+08:00
分享

批量解绑弹性公网IP - BatchDisassociatePublicips

功能介绍

批量解绑弹性公网IP,本接口为异步接口,当前解绑弹性公网IP请求下发成功后会返回job id,此job id为假job,此时解绑弹性公网IP并没有立即完成,需要通过调用弹性公网IP的详情查询弹性公网IP状态,当对应的弹性公网IP状态为未绑定时代表解绑弹性公网IP成功。

调试

您可以在API Explorer中调试该接口,支持自动认证鉴权。

授权信息

账号具备所有API的调用权限,如果使用账号下的IAM用户调用当前API,该IAM用户需具备调用API所需的权限。

  • 如果使用角色与策略授权,具体权限要求请参见权限和授权项
  • 如果使用身份策略授权,需具备如下身份策略权限。

    授权项

    访问级别

    资源类型(*为必须)

    条件键

    别名

    依赖的授权项

    eip:publicIps:disassociateInstance

    Write

    publicip *

    • g:EnterpriseProjectId

    • g:ResourceTag/<tag-key>

    vpc:publicIps:update

    -

URI

PATCH /v2/{project_id}/batchpublicips

表1 路径参数

参数

是否必选

参数类型

描述

project_id

String

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

请求参数

表2 请求Body参数

参数

是否必选

参数类型

描述

publicip_ids

Array of strings

弹性公网ip的id列表。

响应参数

状态码:200

表3 响应Body参数

参数

参数类型

描述

job_ids

Array of strings

job_id,此job_id是假job不能通过查job详情获取结果。返回此job仅代表下发解绑请求成功,此时解绑弹性公网IP并没有立即完成,需要查看弹性公网IP详情接口,如果弹性公网IP为未绑定状态,代表解绑成功。

请求示例

批量解绑id为59e55560-4d2c-40d5-b757-0f5c97b701e4、e83cae01-e68f-4627-84b3-d2d5c4c836bd的弹性公网IP。

PATCH /v2/{project_id}/batchpublicips

{
  "publicip_ids" : [ "59e55560-4d2c-40d5-b757-0f5c97b701e4", "e83cae01-e68f-4627-84b3-d2d5c4c836bd" ]
}

响应示例

状态码:200

OK

{
  "job_ids" : [ "ff8080828436722c0184cdb88e9200a5" ]
}

SDK代码示例

SDK代码示例如下。

批量解绑id为59e55560-4d2c-40d5-b757-0f5c97b701e4、e83cae01-e68f-4627-84b3-d2d5c4c836bd的弹性公网IP。

 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.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 BatchDisassociatePublicipsSolution {

    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");
        String projectId = "{project_id}";

        ICredential auth = new BasicCredentials()
                .withProjectId(projectId)
                .withAk(ak)
                .withSk(sk);

        EipClient client = EipClient.newBuilder()
                .withCredential(auth)
                .withRegion(EipRegion.valueOf("<YOUR REGION>"))
                .build();
        BatchDisassociatePublicipsRequest request = new BatchDisassociatePublicipsRequest();
        BatchDeletePublicIpRequestBody body = new BatchDeletePublicIpRequestBody();
        List<String> listbodyPublicipIds = new ArrayList<>();
        listbodyPublicipIds.add("59e55560-4d2c-40d5-b757-0f5c97b701e4");
        listbodyPublicipIds.add("e83cae01-e68f-4627-84b3-d2d5c4c836bd");
        body.withPublicipIds(listbodyPublicipIds);
        request.withBody(body);
        try {
            BatchDisassociatePublicipsResponse response = client.batchDisassociatePublicips(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());
        }
    }
}

批量解绑id为59e55560-4d2c-40d5-b757-0f5c97b701e4、e83cae01-e68f-4627-84b3-d2d5c4c836bd的弹性公网IP。

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

import os
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 = os.environ["CLOUD_SDK_AK"]
    sk = os.environ["CLOUD_SDK_SK"]
    projectId = "{project_id}"

    credentials = BasicCredentials(ak, sk, projectId)

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

    try:
        request = BatchDisassociatePublicipsRequest()
        listPublicipIdsbody = [
            "59e55560-4d2c-40d5-b757-0f5c97b701e4",
            "e83cae01-e68f-4627-84b3-d2d5c4c836bd"
        ]
        request.body = BatchDeletePublicIpRequestBody(
            publicip_ids=listPublicipIdsbody
        )
        response = client.batch_disassociate_publicips(request)
        print(response)
    except exceptions.ClientRequestException as e:
        print(e.status_code)
        print(e.request_id)
        print(e.error_code)
        print(e.error_msg)

批量解绑id为59e55560-4d2c-40d5-b757-0f5c97b701e4、e83cae01-e68f-4627-84b3-d2d5c4c836bd的弹性公网IP。

 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
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")
    projectId := "{project_id}"

    auth := basic.NewCredentialsBuilder().
        WithAk(ak).
        WithSk(sk).
        WithProjectId(projectId).
        Build()

    client := eip.NewEipClient(
        eip.EipClientBuilder().
            WithRegion(region.ValueOf("<YOUR REGION>")).
            WithCredential(auth).
            Build())

    request := &model.BatchDisassociatePublicipsRequest{}
	var listPublicipIdsbody = []string{
        "59e55560-4d2c-40d5-b757-0f5c97b701e4",
	    "e83cae01-e68f-4627-84b3-d2d5c4c836bd",
    }
	request.Body = &model.BatchDeletePublicIpRequestBody{
		PublicipIds: listPublicipIdsbody,
	}
	response, err := client.BatchDisassociatePublicips(request)
	if err == nil {
        fmt.Printf("%+v\n", response)
    } else {
        fmt.Println(err)
    }
}

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

状态码

状态码

描述

200

OK

错误码

请参见错误码

相关文档