All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.aliyun.sdk.service.ecs20140526.models.CreateNetworkInterfaceRequest Maven / Gradle / Ivy

// This file is auto-generated, don't edit it. Thanks.
package com.aliyun.sdk.service.ecs20140526.models;

import darabonba.core.RequestModel;
import darabonba.core.TeaModel;
import com.aliyun.sdk.gateway.pop.models.*;

/**
 * 
 * {@link CreateNetworkInterfaceRequest} extends {@link RequestModel}
 *
 * 

CreateNetworkInterfaceRequest

*/ public class CreateNetworkInterfaceRequest extends Request { @com.aliyun.core.annotation.Host @com.aliyun.core.annotation.NameInMap("SourceRegionId") private String sourceRegionId; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("BusinessType") private String businessType; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("ClientToken") private String clientToken; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("ConnectionTrackingConfiguration") private ConnectionTrackingConfiguration connectionTrackingConfiguration; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("DeleteOnRelease") private Boolean deleteOnRelease; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("Description") private String description; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("EnhancedNetwork") private EnhancedNetwork enhancedNetwork; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("InstanceType") private String instanceType; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("Ipv4Prefix") private java.util.List < String > ipv4Prefix; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("Ipv4PrefixCount") @com.aliyun.core.annotation.Validation(maximum = 10, minimum = 1) private Integer ipv4PrefixCount; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("Ipv6Address") private java.util.List < String > ipv6Address; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("Ipv6AddressCount") private Integer ipv6AddressCount; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("Ipv6Prefix") private java.util.List < String > ipv6Prefix; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("Ipv6PrefixCount") @com.aliyun.core.annotation.Validation(maximum = 10, minimum = 1) private Integer ipv6PrefixCount; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("NetworkInterfaceName") private String networkInterfaceName; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("NetworkInterfaceTrafficConfig") private NetworkInterfaceTrafficConfig networkInterfaceTrafficConfig; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("NetworkInterfaceTrafficMode") private String networkInterfaceTrafficMode; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("OwnerAccount") private String ownerAccount; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("OwnerId") private Long ownerId; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("PrimaryIpAddress") private String primaryIpAddress; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("PrivateIpAddress") private java.util.List < String > privateIpAddress; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("QueueNumber") private Integer queueNumber; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("QueuePairNumber") private Integer queuePairNumber; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("RegionId") @com.aliyun.core.annotation.Validation(required = true) private String regionId; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("ResourceGroupId") private String resourceGroupId; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("ResourceOwnerAccount") private String resourceOwnerAccount; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("ResourceOwnerId") private Long resourceOwnerId; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("RxQueueSize") private Integer rxQueueSize; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("SecondaryPrivateIpAddressCount") private Integer secondaryPrivateIpAddressCount; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("SecurityGroupId") private String securityGroupId; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("SecurityGroupIds") private java.util.List < String > securityGroupIds; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("Tag") private java.util.List < Tag> tag; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("TxQueueSize") private Integer txQueueSize; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("VSwitchId") @com.aliyun.core.annotation.Validation(required = true) private String vSwitchId; @com.aliyun.core.annotation.Query @com.aliyun.core.annotation.NameInMap("Visible") private Boolean visible; private CreateNetworkInterfaceRequest(Builder builder) { super(builder); this.sourceRegionId = builder.sourceRegionId; this.businessType = builder.businessType; this.clientToken = builder.clientToken; this.connectionTrackingConfiguration = builder.connectionTrackingConfiguration; this.deleteOnRelease = builder.deleteOnRelease; this.description = builder.description; this.enhancedNetwork = builder.enhancedNetwork; this.instanceType = builder.instanceType; this.ipv4Prefix = builder.ipv4Prefix; this.ipv4PrefixCount = builder.ipv4PrefixCount; this.ipv6Address = builder.ipv6Address; this.ipv6AddressCount = builder.ipv6AddressCount; this.ipv6Prefix = builder.ipv6Prefix; this.ipv6PrefixCount = builder.ipv6PrefixCount; this.networkInterfaceName = builder.networkInterfaceName; this.networkInterfaceTrafficConfig = builder.networkInterfaceTrafficConfig; this.networkInterfaceTrafficMode = builder.networkInterfaceTrafficMode; this.ownerAccount = builder.ownerAccount; this.ownerId = builder.ownerId; this.primaryIpAddress = builder.primaryIpAddress; this.privateIpAddress = builder.privateIpAddress; this.queueNumber = builder.queueNumber; this.queuePairNumber = builder.queuePairNumber; this.regionId = builder.regionId; this.resourceGroupId = builder.resourceGroupId; this.resourceOwnerAccount = builder.resourceOwnerAccount; this.resourceOwnerId = builder.resourceOwnerId; this.rxQueueSize = builder.rxQueueSize; this.secondaryPrivateIpAddressCount = builder.secondaryPrivateIpAddressCount; this.securityGroupId = builder.securityGroupId; this.securityGroupIds = builder.securityGroupIds; this.tag = builder.tag; this.txQueueSize = builder.txQueueSize; this.vSwitchId = builder.vSwitchId; this.visible = builder.visible; } public static Builder builder() { return new Builder(); } public static CreateNetworkInterfaceRequest create() { return builder().build(); } @Override public Builder toBuilder() { return new Builder(this); } /** * @return sourceRegionId */ public String getSourceRegionId() { return this.sourceRegionId; } /** * @return businessType */ public String getBusinessType() { return this.businessType; } /** * @return clientToken */ public String getClientToken() { return this.clientToken; } /** * @return connectionTrackingConfiguration */ public ConnectionTrackingConfiguration getConnectionTrackingConfiguration() { return this.connectionTrackingConfiguration; } /** * @return deleteOnRelease */ public Boolean getDeleteOnRelease() { return this.deleteOnRelease; } /** * @return description */ public String getDescription() { return this.description; } /** * @return enhancedNetwork */ public EnhancedNetwork getEnhancedNetwork() { return this.enhancedNetwork; } /** * @return instanceType */ public String getInstanceType() { return this.instanceType; } /** * @return ipv4Prefix */ public java.util.List < String > getIpv4Prefix() { return this.ipv4Prefix; } /** * @return ipv4PrefixCount */ public Integer getIpv4PrefixCount() { return this.ipv4PrefixCount; } /** * @return ipv6Address */ public java.util.List < String > getIpv6Address() { return this.ipv6Address; } /** * @return ipv6AddressCount */ public Integer getIpv6AddressCount() { return this.ipv6AddressCount; } /** * @return ipv6Prefix */ public java.util.List < String > getIpv6Prefix() { return this.ipv6Prefix; } /** * @return ipv6PrefixCount */ public Integer getIpv6PrefixCount() { return this.ipv6PrefixCount; } /** * @return networkInterfaceName */ public String getNetworkInterfaceName() { return this.networkInterfaceName; } /** * @return networkInterfaceTrafficConfig */ public NetworkInterfaceTrafficConfig getNetworkInterfaceTrafficConfig() { return this.networkInterfaceTrafficConfig; } /** * @return networkInterfaceTrafficMode */ public String getNetworkInterfaceTrafficMode() { return this.networkInterfaceTrafficMode; } /** * @return ownerAccount */ public String getOwnerAccount() { return this.ownerAccount; } /** * @return ownerId */ public Long getOwnerId() { return this.ownerId; } /** * @return primaryIpAddress */ public String getPrimaryIpAddress() { return this.primaryIpAddress; } /** * @return privateIpAddress */ public java.util.List < String > getPrivateIpAddress() { return this.privateIpAddress; } /** * @return queueNumber */ public Integer getQueueNumber() { return this.queueNumber; } /** * @return queuePairNumber */ public Integer getQueuePairNumber() { return this.queuePairNumber; } /** * @return regionId */ public String getRegionId() { return this.regionId; } /** * @return resourceGroupId */ public String getResourceGroupId() { return this.resourceGroupId; } /** * @return resourceOwnerAccount */ public String getResourceOwnerAccount() { return this.resourceOwnerAccount; } /** * @return resourceOwnerId */ public Long getResourceOwnerId() { return this.resourceOwnerId; } /** * @return rxQueueSize */ public Integer getRxQueueSize() { return this.rxQueueSize; } /** * @return secondaryPrivateIpAddressCount */ public Integer getSecondaryPrivateIpAddressCount() { return this.secondaryPrivateIpAddressCount; } /** * @return securityGroupId */ public String getSecurityGroupId() { return this.securityGroupId; } /** * @return securityGroupIds */ public java.util.List < String > getSecurityGroupIds() { return this.securityGroupIds; } /** * @return tag */ public java.util.List < Tag> getTag() { return this.tag; } /** * @return txQueueSize */ public Integer getTxQueueSize() { return this.txQueueSize; } /** * @return vSwitchId */ public String getVSwitchId() { return this.vSwitchId; } /** * @return visible */ public Boolean getVisible() { return this.visible; } public static final class Builder extends Request.Builder { private String sourceRegionId; private String businessType; private String clientToken; private ConnectionTrackingConfiguration connectionTrackingConfiguration; private Boolean deleteOnRelease; private String description; private EnhancedNetwork enhancedNetwork; private String instanceType; private java.util.List < String > ipv4Prefix; private Integer ipv4PrefixCount; private java.util.List < String > ipv6Address; private Integer ipv6AddressCount; private java.util.List < String > ipv6Prefix; private Integer ipv6PrefixCount; private String networkInterfaceName; private NetworkInterfaceTrafficConfig networkInterfaceTrafficConfig; private String networkInterfaceTrafficMode; private String ownerAccount; private Long ownerId; private String primaryIpAddress; private java.util.List < String > privateIpAddress; private Integer queueNumber; private Integer queuePairNumber; private String regionId; private String resourceGroupId; private String resourceOwnerAccount; private Long resourceOwnerId; private Integer rxQueueSize; private Integer secondaryPrivateIpAddressCount; private String securityGroupId; private java.util.List < String > securityGroupIds; private java.util.List < Tag> tag; private Integer txQueueSize; private String vSwitchId; private Boolean visible; private Builder() { super(); } private Builder(CreateNetworkInterfaceRequest request) { super(request); this.sourceRegionId = request.sourceRegionId; this.businessType = request.businessType; this.clientToken = request.clientToken; this.connectionTrackingConfiguration = request.connectionTrackingConfiguration; this.deleteOnRelease = request.deleteOnRelease; this.description = request.description; this.enhancedNetwork = request.enhancedNetwork; this.instanceType = request.instanceType; this.ipv4Prefix = request.ipv4Prefix; this.ipv4PrefixCount = request.ipv4PrefixCount; this.ipv6Address = request.ipv6Address; this.ipv6AddressCount = request.ipv6AddressCount; this.ipv6Prefix = request.ipv6Prefix; this.ipv6PrefixCount = request.ipv6PrefixCount; this.networkInterfaceName = request.networkInterfaceName; this.networkInterfaceTrafficConfig = request.networkInterfaceTrafficConfig; this.networkInterfaceTrafficMode = request.networkInterfaceTrafficMode; this.ownerAccount = request.ownerAccount; this.ownerId = request.ownerId; this.primaryIpAddress = request.primaryIpAddress; this.privateIpAddress = request.privateIpAddress; this.queueNumber = request.queueNumber; this.queuePairNumber = request.queuePairNumber; this.regionId = request.regionId; this.resourceGroupId = request.resourceGroupId; this.resourceOwnerAccount = request.resourceOwnerAccount; this.resourceOwnerId = request.resourceOwnerId; this.rxQueueSize = request.rxQueueSize; this.secondaryPrivateIpAddressCount = request.secondaryPrivateIpAddressCount; this.securityGroupId = request.securityGroupId; this.securityGroupIds = request.securityGroupIds; this.tag = request.tag; this.txQueueSize = request.txQueueSize; this.vSwitchId = request.vSwitchId; this.visible = request.visible; } /** * SourceRegionId. */ public Builder sourceRegionId(String sourceRegionId) { this.putHostParameter("SourceRegionId", sourceRegionId); this.sourceRegionId = sourceRegionId; return this; } /** *
*

This parameter is no longer used.

*
* * example: *

null

*/ public Builder businessType(String businessType) { this.putQueryParameter("BusinessType", businessType); this.businessType = businessType; return this; } /** *

The client token that is used to ensure the idempotence of the request. You can use the client to generate the token, but you must make sure that the token is unique among different requests. The token can contain only ASCII characters and cannot exceed 64 characters in length. For more information, see How to ensure idempotence.

* * example: *

123e4567-e89b-12d3-a456-426655440000

*/ public Builder clientToken(String clientToken) { this.putQueryParameter("ClientToken", clientToken); this.clientToken = clientToken; return this; } /** *
*

This parameter is not publicly available.

*
*/ public Builder connectionTrackingConfiguration(ConnectionTrackingConfiguration connectionTrackingConfiguration) { this.putQueryParameter("ConnectionTrackingConfiguration", connectionTrackingConfiguration); this.connectionTrackingConfiguration = connectionTrackingConfiguration; return this; } /** *

Specifies whether to release the ENI when the associated instance is released. Valid values:

*
    *
  • true
  • *
  • false
  • *
* * example: *

true

*/ public Builder deleteOnRelease(Boolean deleteOnRelease) { this.putQueryParameter("DeleteOnRelease", deleteOnRelease); this.deleteOnRelease = deleteOnRelease; return this; } /** *

The description of the ENI. The description must be 2 to 256 characters in length and cannot start with http:// or https://.

*

This parameter is empty by default.

* * example: *

testDescription

*/ public Builder description(String description) { this.putQueryParameter("Description", description); this.description = description; return this; } /** *
*

This parameter is unavailable.

*
*/ public Builder enhancedNetwork(EnhancedNetwork enhancedNetwork) { this.putQueryParameter("EnhancedNetwork", enhancedNetwork); this.enhancedNetwork = enhancedNetwork; return this; } /** *

The type of the ENI. Valid values:

*
    *
  • Secondary: secondary ENI.
  • *
  • Trunk: trunk ENI. This value is in invitational preview.
  • *
*

Default value: Secondary.

* * example: *

null

*/ public Builder instanceType(String instanceType) { this.putQueryParameter("InstanceType", instanceType); this.instanceType = instanceType; return this; } /** *

IPv4 prefixes to assign to the ENI. Valid values of N: 1 to 10.

*
*

To assign IPv4 prefixes to the ENI, you must specify the Ipv4Prefix.N or Ipv4PrefixCount parameter, but not both.

*
*/ public Builder ipv4Prefix(java.util.List < String > ipv4Prefix) { this.putQueryParameter("Ipv4Prefix", ipv4Prefix); this.ipv4Prefix = ipv4Prefix; return this; } /** *

The number of IPv4 prefixes to assign to the ENI. Valid values: 1 to 10.

*
*

To assign IPv4 prefixes to the ENI, you must specify the Ipv4Prefix.N or Ipv4PrefixCount parameter, but not both.

*
* * example: *

hide

*/ public Builder ipv4PrefixCount(Integer ipv4PrefixCount) { this.putQueryParameter("Ipv4PrefixCount", ipv4PrefixCount); this.ipv4PrefixCount = ipv4PrefixCount; return this; } /** *

IPv6 addresses to assign to the ENI. Valid values of N: 1 to 10.

*

Example: Ipv6Address.1=2001:db8:1234:1a00::****

*
*

To assign IPv6 addresses to the ENI, you must specify the Ipv6Addresses.N or Ipv6AddressCount parameter, but not both.

*
* * example: *

2001:db8:1234:1a00::****

*/ public Builder ipv6Address(java.util.List < String > ipv6Address) { this.putQueryParameter("Ipv6Address", ipv6Address); this.ipv6Address = ipv6Address; return this; } /** *

The number of IPv6 addresses to randomly generate for the ENI. Valid values: 1 to 10.

*
*

To assign IPv6 addresses to the ENI, you must specify the Ipv6Addresses.N or Ipv6AddressCount parameter, but not both.

*
* * example: *

1

*/ public Builder ipv6AddressCount(Integer ipv6AddressCount) { this.putQueryParameter("Ipv6AddressCount", ipv6AddressCount); this.ipv6AddressCount = ipv6AddressCount; return this; } /** *

IPv6 prefixes to assign to the ENI. Valid values of N: 1 to 10.

*
*

To assign IPv6 prefixes to the ENI, you must specify the Ipv6Prefix.N or Ipv6PrefixCount parameter, but not both.

*
*/ public Builder ipv6Prefix(java.util.List < String > ipv6Prefix) { this.putQueryParameter("Ipv6Prefix", ipv6Prefix); this.ipv6Prefix = ipv6Prefix; return this; } /** *

The number of IPv6 prefixes to assign to the ENI. Valid values: 1 to 10.

*
*

To assign IPv6 prefixes to the ENI, you must specify the Ipv6Prefix.N or Ipv6PrefixCount parameter, but not both.

*
* * example: *

hide

*/ public Builder ipv6PrefixCount(Integer ipv6PrefixCount) { this.putQueryParameter("Ipv6PrefixCount", ipv6PrefixCount); this.ipv6PrefixCount = ipv6PrefixCount; return this; } /** *

The name of the ENI. The name must be 2 to 128 characters in length and can contain letters, digits, colons (:), underscores (_), periods (.), and hyphens (-).

*

This parameter is left empty by default.

* * example: *

testNetworkInterfaceName

*/ public Builder networkInterfaceName(String networkInterfaceName) { this.putQueryParameter("NetworkInterfaceName", networkInterfaceName); this.networkInterfaceName = networkInterfaceName; return this; } /** *

The communication settings of the ENI.

*/ public Builder networkInterfaceTrafficConfig(NetworkInterfaceTrafficConfig networkInterfaceTrafficConfig) { this.putQueryParameter("NetworkInterfaceTrafficConfig", networkInterfaceTrafficConfig); this.networkInterfaceTrafficConfig = networkInterfaceTrafficConfig; return this; } /** *

The communication mode of the ENI. Valid values:

*
    *
  • Standard: uses the TCP communication mode.
  • *
  • HighPerformance: uses the remote direct memory access (RDMA) communication mode with Elastic RDMA Interface (ERI) enabled.
  • *
*
*

ENIs in RDMA mode can be attached only to instances of the instance types that support ERIs. The number of ENIs in RDMA mode that are attached to an instance cannot exceed the maximum number of ENIs that the instance type supports. For more information, see Overview of ECS instance families and Configure eRDMA on an enterprise-level instance.

*
*

Default value: Standard.

* * example: *

Standard

*/ public Builder networkInterfaceTrafficMode(String networkInterfaceTrafficMode) { this.putQueryParameter("NetworkInterfaceTrafficMode", networkInterfaceTrafficMode); this.networkInterfaceTrafficMode = networkInterfaceTrafficMode; return this; } /** * OwnerAccount. */ public Builder ownerAccount(String ownerAccount) { this.putQueryParameter("OwnerAccount", ownerAccount); this.ownerAccount = ownerAccount; return this; } /** * OwnerId. */ public Builder ownerId(Long ownerId) { this.putQueryParameter("OwnerId", ownerId); this.ownerId = ownerId; return this; } /** *

The primary private IP address of the ENI.

*

The specified IP address must be an idle IP address within the CIDR block of the vSwitch with which to associate the ENI. If this parameter is not specified, an idle IP address is assigned from within the vSwitch CIDR block at random.

* * example: *

172.17.**.**

*/ public Builder primaryIpAddress(String primaryIpAddress) { this.putQueryParameter("PrimaryIpAddress", primaryIpAddress); this.primaryIpAddress = primaryIpAddress; return this; } /** *

Secondary private IP addresses to assign to the ENI. The IP addresses must be idle IP addresses in the CIDR block of the vSwitch with which to associate the ENI. Valid values of N: 0 to 10.

*
*

To assign secondary private IP addresses to the ENI, you can specify the PrivateIpAddress.N or SecondaryPrivateIpAddressCount parameter, but not both.

*
* * example: *

172.17.**.**

*/ public Builder privateIpAddress(java.util.List < String > privateIpAddress) { this.putQueryParameter("PrivateIpAddress", privateIpAddress); this.privateIpAddress = privateIpAddress; return this; } /** *

The number of queues supported by the ENI. Valid values: 1 to 2048.

*

When you attach the ENI to an instance, make sure that the value of this parameter is less than the maximum number of queues per ENI that is allowed for the instance type. To view the maximum number of queues per ENI allowed for an instance type, you can call the DescribeInstanceTypes operation and then check the return value of MaximumQueueNumberPerEni.

*

This parameter is left empty by default. If you do not specify this parameter, the default number of queues per ENI for the instance type of an instance is used when you attach the ENI to the instance. To view the default number of queues per ENI for an instance type, you can call the DescribeInstanceTypes operation and then check the return value of SecondaryEniQueueNumber.

* * example: *

1

*/ public Builder queueNumber(Integer queueNumber) { this.putQueryParameter("QueueNumber", queueNumber); this.queueNumber = queueNumber; return this; } /** *
*

This parameter is in invitational preview and is not publicly available.

*
* * example: *

22

*/ public Builder queuePairNumber(Integer queuePairNumber) { this.putQueryParameter("QueuePairNumber", queuePairNumber); this.queuePairNumber = queuePairNumber; return this; } /** *

The region in which to create the ENI. You can call the DescribeRegions operation to query the most recent region list.

*

This parameter is required.

* * example: *

cn-hangzhou

*/ public Builder regionId(String regionId) { this.putQueryParameter("RegionId", regionId); this.regionId = regionId; return this; } /** *

The ID of the resource group to which you want to assign the ENI. You can call the ListResourceGroups operation to query the most recent resource group list.

* * example: *

rg-bp67acfmxazb4ph****

*/ public Builder resourceGroupId(String resourceGroupId) { this.putQueryParameter("ResourceGroupId", resourceGroupId); this.resourceGroupId = resourceGroupId; return this; } /** * ResourceOwnerAccount. */ public Builder resourceOwnerAccount(String resourceOwnerAccount) { this.putQueryParameter("ResourceOwnerAccount", resourceOwnerAccount); this.resourceOwnerAccount = resourceOwnerAccount; return this; } /** * ResourceOwnerId. */ public Builder resourceOwnerId(Long resourceOwnerId) { this.putQueryParameter("ResourceOwnerId", resourceOwnerId); this.resourceOwnerId = resourceOwnerId; return this; } /** *

The receive (Rx) queue depth of the ENI.

*

Take note of the following items:

*
    *
  • The Rx queue depth of an ENI must be the same as the Tx queue depth of the ENI. Valid values: powers of 2 in the range of 8192 to 16384.
  • *
  • A larger Rx queue depth yields higher inbound throughput but consumes more memory.
  • *
* * example: *

8192

*/ public Builder rxQueueSize(Integer rxQueueSize) { this.putQueryParameter("RxQueueSize", rxQueueSize); this.rxQueueSize = rxQueueSize; return this; } /** *

The number of private IP addresses to be assigned by ECS. Valid values: 1 to 49.

* * example: *

1

*/ public Builder secondaryPrivateIpAddressCount(Integer secondaryPrivateIpAddressCount) { this.putQueryParameter("SecondaryPrivateIpAddressCount", secondaryPrivateIpAddressCount); this.secondaryPrivateIpAddressCount = secondaryPrivateIpAddressCount; return this; } /** *

The ID of the security group to which to assign the ENI. The security group and the ENI must belong to the same VPC.

*
*

You must specify SecurityGroupId or SecurityGroupIds.N but not both.

*
* * example: *

sg-bp1fg655nh68xyz9i****

*/ public Builder securityGroupId(String securityGroupId) { this.putQueryParameter("SecurityGroupId", securityGroupId); this.securityGroupId = securityGroupId; return this; } /** *

The IDs of security groups to which to assign the ENI. The security groups and the ENI must belong to the same VPC. The valid values of N are determined based on the maximum number of security groups to which an ENI can be assigned. For more information, see Limits.

*
*

You must specify SecurityGroupId or SecurityGroupIds.N but not both.

*
* * example: *

sg-bp1fg655nh68xyz9i****

*/ public Builder securityGroupIds(java.util.List < String > securityGroupIds) { this.putQueryParameter("SecurityGroupIds", securityGroupIds); this.securityGroupIds = securityGroupIds; return this; } /** *

The tags to add to the ENI.

*/ public Builder tag(java.util.List < Tag> tag) { this.putQueryParameter("Tag", tag); this.tag = tag; return this; } /** *

The transmit (Tx) queue depth of the ENI.

*

Take note of the following items:

*
    *
  • The Tx queue depth of an ENI must be the same as the Rx queue depth of the ENI. Valid values: powers of 2 in the range of 8192 to 16384.
  • *
  • A larger Tx queue depth yields higher outbound throughput but consumes more memory.
  • *
* * example: *

8192

*/ public Builder txQueueSize(Integer txQueueSize) { this.putQueryParameter("TxQueueSize", txQueueSize); this.txQueueSize = txQueueSize; return this; } /** *

The ID of the vSwitch with which to associate the ENI. Private IP addresses are assigned to the ENI from within the CIDR block of the vSwitch.

*

This parameter is required.

* * example: *

vsw-bp1s5fnvk4gn2tws03****

*/ public Builder vSwitchId(String vSwitchId) { this.putQueryParameter("VSwitchId", vSwitchId); this.vSwitchId = vSwitchId; return this; } /** *
*

This parameter is no longer used.

*
* * example: *

null

*/ public Builder visible(Boolean visible) { this.putQueryParameter("Visible", visible); this.visible = visible; return this; } @Override public CreateNetworkInterfaceRequest build() { return new CreateNetworkInterfaceRequest(this); } } /** * * {@link CreateNetworkInterfaceRequest} extends {@link TeaModel} * *

CreateNetworkInterfaceRequest

*/ public static class ConnectionTrackingConfiguration extends TeaModel { @com.aliyun.core.annotation.NameInMap("TcpClosedAndTimeWaitTimeout") private Integer tcpClosedAndTimeWaitTimeout; @com.aliyun.core.annotation.NameInMap("TcpEstablishedTimeout") private Integer tcpEstablishedTimeout; @com.aliyun.core.annotation.NameInMap("UdpTimeout") private Integer udpTimeout; private ConnectionTrackingConfiguration(Builder builder) { this.tcpClosedAndTimeWaitTimeout = builder.tcpClosedAndTimeWaitTimeout; this.tcpEstablishedTimeout = builder.tcpEstablishedTimeout; this.udpTimeout = builder.udpTimeout; } public static Builder builder() { return new Builder(); } public static ConnectionTrackingConfiguration create() { return builder().build(); } /** * @return tcpClosedAndTimeWaitTimeout */ public Integer getTcpClosedAndTimeWaitTimeout() { return this.tcpClosedAndTimeWaitTimeout; } /** * @return tcpEstablishedTimeout */ public Integer getTcpEstablishedTimeout() { return this.tcpEstablishedTimeout; } /** * @return udpTimeout */ public Integer getUdpTimeout() { return this.udpTimeout; } public static final class Builder { private Integer tcpClosedAndTimeWaitTimeout; private Integer tcpEstablishedTimeout; private Integer udpTimeout; /** *
*

This parameter is not publicly available.

*
* * example: *

3

*/ public Builder tcpClosedAndTimeWaitTimeout(Integer tcpClosedAndTimeWaitTimeout) { this.tcpClosedAndTimeWaitTimeout = tcpClosedAndTimeWaitTimeout; return this; } /** *
*

This parameter is not publicly available.

*
* * example: *

910

*/ public Builder tcpEstablishedTimeout(Integer tcpEstablishedTimeout) { this.tcpEstablishedTimeout = tcpEstablishedTimeout; return this; } /** *
*

This parameter is not publicly available.

*
* * example: *

30

*/ public Builder udpTimeout(Integer udpTimeout) { this.udpTimeout = udpTimeout; return this; } public ConnectionTrackingConfiguration build() { return new ConnectionTrackingConfiguration(this); } } } /** * * {@link CreateNetworkInterfaceRequest} extends {@link TeaModel} * *

CreateNetworkInterfaceRequest

*/ public static class EnhancedNetwork extends TeaModel { @com.aliyun.core.annotation.NameInMap("EnableSriov") private Boolean enableSriov; private EnhancedNetwork(Builder builder) { this.enableSriov = builder.enableSriov; } public static Builder builder() { return new Builder(); } public static EnhancedNetwork create() { return builder().build(); } /** * @return enableSriov */ public Boolean getEnableSriov() { return this.enableSriov; } public static final class Builder { private Boolean enableSriov; /** *
*

This parameter is not publicly available.

*
* * example: *

true

*/ public Builder enableSriov(Boolean enableSriov) { this.enableSriov = enableSriov; return this; } public EnhancedNetwork build() { return new EnhancedNetwork(this); } } } /** * * {@link CreateNetworkInterfaceRequest} extends {@link TeaModel} * *

CreateNetworkInterfaceRequest

*/ public static class NetworkInterfaceTrafficConfig extends TeaModel { @com.aliyun.core.annotation.NameInMap("NetworkInterfaceTrafficMode") private String networkInterfaceTrafficMode; @com.aliyun.core.annotation.NameInMap("QueueNumber") private Integer queueNumber; @com.aliyun.core.annotation.NameInMap("QueuePairNumber") private Integer queuePairNumber; @com.aliyun.core.annotation.NameInMap("RxQueueSize") private Integer rxQueueSize; @com.aliyun.core.annotation.NameInMap("TxQueueSize") private Integer txQueueSize; private NetworkInterfaceTrafficConfig(Builder builder) { this.networkInterfaceTrafficMode = builder.networkInterfaceTrafficMode; this.queueNumber = builder.queueNumber; this.queuePairNumber = builder.queuePairNumber; this.rxQueueSize = builder.rxQueueSize; this.txQueueSize = builder.txQueueSize; } public static Builder builder() { return new Builder(); } public static NetworkInterfaceTrafficConfig create() { return builder().build(); } /** * @return networkInterfaceTrafficMode */ public String getNetworkInterfaceTrafficMode() { return this.networkInterfaceTrafficMode; } /** * @return queueNumber */ public Integer getQueueNumber() { return this.queueNumber; } /** * @return queuePairNumber */ public Integer getQueuePairNumber() { return this.queuePairNumber; } /** * @return rxQueueSize */ public Integer getRxQueueSize() { return this.rxQueueSize; } /** * @return txQueueSize */ public Integer getTxQueueSize() { return this.txQueueSize; } public static final class Builder { private String networkInterfaceTrafficMode; private Integer queueNumber; private Integer queuePairNumber; private Integer rxQueueSize; private Integer txQueueSize; /** *

The communication mode of the ENI.

* * example: *

HighPerformance

*/ public Builder networkInterfaceTrafficMode(String networkInterfaceTrafficMode) { this.networkInterfaceTrafficMode = networkInterfaceTrafficMode; return this; } /** *

The number of queues supported by the ENI.

* * example: *

8

*/ public Builder queueNumber(Integer queueNumber) { this.queueNumber = queueNumber; return this; } /** *

The number of queues supported by the ERI.

* * example: *

8

*/ public Builder queuePairNumber(Integer queuePairNumber) { this.queuePairNumber = queuePairNumber; return this; } /** *

The receive (Rx) queue depth of the ENI.

* * example: *

8192

*/ public Builder rxQueueSize(Integer rxQueueSize) { this.rxQueueSize = rxQueueSize; return this; } /** *

The transmit (Tx) queue depth of the ENI.

* * example: *

8192

*/ public Builder txQueueSize(Integer txQueueSize) { this.txQueueSize = txQueueSize; return this; } public NetworkInterfaceTrafficConfig build() { return new NetworkInterfaceTrafficConfig(this); } } } /** * * {@link CreateNetworkInterfaceRequest} extends {@link TeaModel} * *

CreateNetworkInterfaceRequest

*/ public static class Tag extends TeaModel { @com.aliyun.core.annotation.NameInMap("Key") private String key; @com.aliyun.core.annotation.NameInMap("Value") private String value; private Tag(Builder builder) { this.key = builder.key; this.value = builder.value; } public static Builder builder() { return new Builder(); } public static Tag create() { return builder().build(); } /** * @return key */ public String getKey() { return this.key; } /** * @return value */ public String getValue() { return this.value; } public static final class Builder { private String key; private String value; /** *

The key of tag N to add to the ENI. Valid values of N: 1 to 20. The tag key cannot be an empty string. The tag key can be up to 128 characters in length. It cannot start with aliyun or acs: and cannot contain http:// or https://.

* * example: *

TestKey

*/ public Builder key(String key) { this.key = key; return this; } /** *

The value of tag N to add to the ENI. Valid values of N: 1 to 20. The tag value can be an empty string. The tag value can be up to 128 characters in length and cannot contain http:// or https://.

* * example: *

TestValue

*/ public Builder value(String value) { this.value = value; return this; } public Tag build() { return new Tag(this); } } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy