本文展示了如何通过调用阿里云ECS Java SDK来删除弹性网卡。
操作场景
删除弹性网卡为异步操作,获得返回结果仅代表删除弹性网卡请求发送成功,删除弹性网卡是否成功有两种方式可以获取。您可以根据业务场景,选择不同的示例。
注意事项
弹性网卡必须处于可用(Available)状态。
如果弹性网卡已经附加到ECS实例,必须先从实例分离(DetachNetworkInterface),才能删除弹性网卡。
示例1
适用于对弹性网卡删除时延要求不高、资源量较小的场景,通过轮询网卡状态来获取弹性网卡操作结果。
发送删除弹性网卡命令。
轮询弹性网卡查询接口,查询弹性网卡是否存在,判断是否删除成功。
轮询弹性网卡查询建议采用退避策略,时间间隔采用2、1、1、1秒。
轮询弹性网卡查询接口限制在60次/秒。
当前示例基于阿里云SDK V2.0版本编写。
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import com.aliyun.ecs20140526.Client;
import com.aliyun.ecs20140526.models.DeleteNetworkInterfaceRequest;
import com.aliyun.ecs20140526.models.DeleteNetworkInterfaceResponse;
import com.aliyun.ecs20140526.models.DescribeNetworkInterfacesRequest;
import com.aliyun.ecs20140526.models.DescribeNetworkInterfacesResponse;
import com.aliyun.ecs20140526.models.DescribeNetworkInterfacesResponseBody.DescribeNetworkInterfacesResponseBodyNetworkInterfaceSetsNetworkInterfaceSet;
import com.aliyun.tea.TeaException;
import com.aliyun.teaopenapi.models.Config;
import com.aliyun.teautil.models.RuntimeOptions;
/**
* 该示例基于轮询弹性网卡查询接口获取弹性网卡操作结果
*/
public class DeleteNetworkInterfaceWithEniDescribe {
private static final long DESC_INTERVAL_MS = 2000;
/**
* delete eni
*
* @param regionId
* @param eniId
* @return
*/
public static DeleteNetworkInterfaceResponse deleteNetworkInterface(Client ecsClient, String regionId,
String eniId) {
DeleteNetworkInterfaceRequest request = new DeleteNetworkInterfaceRequest();
request.setRegionId(regionId);
request.setNetworkInterfaceId(eniId);
DeleteNetworkInterfaceResponse response = null;
try {
//用来设置个性化的策略
RuntimeOptions runtime = new RuntimeOptions();
response = ecsClient.deleteNetworkInterfaceWithOptions(request, runtime);
System.out.printf(
"delete network interface %s send request success. Request id is %s.%n",
eniId, response.getBody().getRequestId());
} catch (TeaException te) {
System.out.println("ErrCode:" + te.getCode());
System.out.println("ErrMsg:" + te.getMessage());
System.out.println("RequestId:" + te.getData().get("RequestId"));
} catch (Exception e) {
System.out.println("ErrCode:" + e.getMessage());
}
return response;
}
/**
* describe eni
*
* @param regionId
* @param eniId
* @return
*/
public static DescribeNetworkInterfacesResponseBodyNetworkInterfaceSetsNetworkInterfaceSet describeNetworkInterface(
Client ecsClient, String regionId, String eniId) {
List<DescribeNetworkInterfacesResponseBodyNetworkInterfaceSetsNetworkInterfaceSet> networkInterfaceSetList;
try {
DescribeNetworkInterfacesRequest request = new DescribeNetworkInterfacesRequest();
request.setRegionId(regionId);
request.setNetworkInterfaceId(Collections.singletonList(eniId));
//用来设置个性化的策略
RuntimeOptions runtime = new RuntimeOptions();
DescribeNetworkInterfacesResponse response = ecsClient.describeNetworkInterfacesWithOptions(request,
runtime);
networkInterfaceSetList = response.getBody().getNetworkInterfaceSets().getNetworkInterfaceSet();
if (networkInterfaceSetList != null && networkInterfaceSetList.size() > 0) {
return networkInterfaceSetList.get(0);
}
} catch (TeaException te) {
System.out.println("ErrCode:" + te.getCode());
System.out.println("ErrMsg:" + te.getMessage());
System.out.println("RequestId:" + te.getData().get("RequestId"));
} catch (Exception e) {
System.out.println("ErrCode:" + e.getMessage());
}
return null;
}
/**
* Check whether eni successfully deleted with max retry count
*
* @param ecsClient
* @param regionId
* @param eniId
* @param maxDescTimes
* @return
*/
public static boolean isDeleteNetworkInterfaceSuccess(Client ecsClient, String regionId, String eniId,
int maxDescTimes) {
boolean result = false;
for (int i = 0; i < maxDescTimes; i++) {
DescribeNetworkInterfacesResponseBodyNetworkInterfaceSetsNetworkInterfaceSet networkInterface
= describeNetworkInterface(ecsClient, regionId, eniId);
if (Objects.isNull(networkInterface)) {
result = true;
break;
}
interval(DESC_INTERVAL_MS);
}
return result;
}
public static void interval(long intervalMs) {
try {
Thread.sleep(intervalMs);
} catch (InterruptedException ignored) {
}
}
/**
* 使用AK&SK初始化账号Client。
*
* 本示例通过从环境变量中读取AccessKey,来实现API访问的身份验证。请根据你的生产环境要求适当调整。
* 避免AK&SK等关键信息在代码中明文存储是云上安全红线!
*
* @return Client
* @throws Exception
*/
public static Client createClient() throws Exception {
Config config = new Config()
.setAccessKeyId(System.getenv("ALIBABA_CLOUD_ACCESS_KEY_ID"))
.setAccessKeySecret(System.getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET"));
config.endpoint = "<yourEcsEndPoint>";
return new Client(config);
}
public static void main(String[] args) throws Exception {
String regionId = "<regionId>";
String eniId = "<yourEniId>";
int maxRetryCnt = 3;
Client ecsClient = createClient();
deleteNetworkInterface(ecsClient, regionId, eniId);
if (isDeleteNetworkInterfaceSuccess(ecsClient, regionId, eniId, maxRetryCnt)) {
System.out.printf(
"Async delete network interface %s success.", eniId);
} else {
System.out.printf(
"Async delete network interface %s fail. Please try again.", eniId);
}
}
}
示例2
适用于对弹性网卡删除时延要求较高、资源量较大的场景,通过事件驱动架构方式来获取弹性网卡操作结果。该方式使用MNS来获取消息,会产生一定的费用。MNS费用详见价格说明。
准备工作
创建队列,具体操作,请参见创建队列。
本示例中,自定义队列名称为eni-operate-completed-event,其他配置项保持默认配置。
创建系统事件报警规则,具体操作,请参见创建系统事件报警规则。
本示例中,您需要注意以下参数配置。
报警规则名称:自定义名称。本示例中,自定义事件通知名称为eni-event-test-rule。
产品类型:选择云服务器ECS。
事件类型:选择状态通知。
事件等级:选择信息。事件名称:选择网卡操作完成。资源范围:本示例保持默认配置。您可以根据需要自行设置。
报警方式:本示例仅选中消息服务队列,并选择已创建的eni-operate-completed-event队列,设置地域与队列。
示例代码
示例代码通过监听MNS消息来获取弹性网卡操作结果。
发送删除弹性网卡命令。
通过接收MNS消息获取弹性网卡删除结果。