#[non_exhaustive]pub struct InstanceNetworkInterfaceSpecification {Show 22 fields
    pub associate_public_ip_address: Option<bool>,
    pub delete_on_termination: Option<bool>,
    pub description: Option<String>,
    pub device_index: Option<i32>,
    pub groups: Option<Vec<String>>,
    pub ipv6_address_count: Option<i32>,
    pub ipv6_addresses: Option<Vec<InstanceIpv6Address>>,
    pub network_interface_id: Option<String>,
    pub private_ip_address: Option<String>,
    pub private_ip_addresses: Option<Vec<PrivateIpAddressSpecification>>,
    pub secondary_private_ip_address_count: Option<i32>,
    pub subnet_id: Option<String>,
    pub associate_carrier_ip_address: Option<bool>,
    pub interface_type: Option<String>,
    pub network_card_index: Option<i32>,
    pub ipv4_prefixes: Option<Vec<Ipv4PrefixSpecificationRequest>>,
    pub ipv4_prefix_count: Option<i32>,
    pub ipv6_prefixes: Option<Vec<Ipv6PrefixSpecificationRequest>>,
    pub ipv6_prefix_count: Option<i32>,
    pub primary_ipv6: Option<bool>,
    pub ena_srd_specification: Option<EnaSrdSpecificationRequest>,
    pub connection_tracking_specification: Option<ConnectionTrackingSpecificationRequest>,
}Expand description
Describes a network interface.
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.associate_public_ip_address: Option<bool>Indicates whether to assign a public IPv4 address to an instance you launch in a VPC. The public IP address can only be assigned to a network interface for eth0, and can only be assigned to a new network interface, not an existing one. You cannot specify more than one network interface in the request. If launching into a default subnet, the default value is true.
Amazon Web Services charges for all public IPv4 addresses, including public IPv4 addresses associated with running instances and Elastic IP addresses. For more information, see the Public IPv4 Address tab on the Amazon VPC pricing page.
delete_on_termination: Option<bool>If set to true, the interface is deleted when the instance is terminated. You can specify true only if creating a new network interface when launching an instance.
description: Option<String>The description of the network interface. Applies only if creating a network interface when launching an instance.
device_index: Option<i32>The position of the network interface in the attachment order. A primary network interface has a device index of 0.
If you specify a network interface when launching an instance, you must specify the device index.
groups: Option<Vec<String>>The IDs of the security groups for the network interface. Applies only if creating a network interface when launching an instance.
ipv6_address_count: Option<i32>A number of IPv6 addresses to assign to the network interface. Amazon EC2 chooses the IPv6 addresses from the range of the subnet. You cannot specify this option and the option to assign specific IPv6 addresses in the same request. You can specify this option if you've specified a minimum number of instances to launch.
ipv6_addresses: Option<Vec<InstanceIpv6Address>>The IPv6 addresses to assign to the network interface. You cannot specify this option and the option to assign a number of IPv6 addresses in the same request. You cannot specify this option if you've specified a minimum number of instances to launch.
network_interface_id: Option<String>The ID of the network interface.
If you are creating a Spot Fleet, omit this parameter because you can’t specify a network interface ID in a launch specification.
private_ip_address: Option<String>The private IPv4 address of the network interface. Applies only if creating a network interface when launching an instance. You cannot specify this option if you're launching more than one instance in a RunInstances request.
private_ip_addresses: Option<Vec<PrivateIpAddressSpecification>>The private IPv4 addresses to assign to the network interface. Only one private IPv4 address can be designated as primary. You cannot specify this option if you're launching more than one instance in a RunInstances request.
secondary_private_ip_address_count: Option<i32>The number of secondary private IPv4 addresses. You can't specify this option and specify more than one private IP address using the private IP addresses option. You cannot specify this option if you're launching more than one instance in a RunInstances request.
subnet_id: Option<String>The ID of the subnet associated with the network interface. Applies only if creating a network interface when launching an instance.
associate_carrier_ip_address: Option<bool>Indicates whether to assign a carrier IP address to the network interface.
You can only assign a carrier IP address to a network interface that is in a subnet in a Wavelength Zone. For more information about carrier IP addresses, see Carrier IP address in the Amazon Web Services Wavelength Developer Guide.
interface_type: Option<String>The type of network interface.
Valid values: interface | efa
network_card_index: Option<i32>The index of the network card. Some instance types support multiple network cards. The primary network interface must be assigned to network card index 0. The default is network card index 0.
If you are using RequestSpotInstances to create Spot Instances, omit this parameter because you can’t specify the network card index when using this API. To specify the network card index, use RunInstances.
ipv4_prefixes: Option<Vec<Ipv4PrefixSpecificationRequest>>The IPv4 delegated prefixes to be assigned to the network interface. You cannot use this option if you use the Ipv4PrefixCount option.
ipv4_prefix_count: Option<i32>The number of IPv4 delegated prefixes to be automatically assigned to the network interface. You cannot use this option if you use the Ipv4Prefix option.
ipv6_prefixes: Option<Vec<Ipv6PrefixSpecificationRequest>>The IPv6 delegated prefixes to be assigned to the network interface. You cannot use this option if you use the Ipv6PrefixCount option.
ipv6_prefix_count: Option<i32>The number of IPv6 delegated prefixes to be automatically assigned to the network interface. You cannot use this option if you use the Ipv6Prefix option.
primary_ipv6: Option<bool>The primary IPv6 address of the network interface. When you enable an IPv6 GUA address to be a primary IPv6, the first IPv6 GUA will be made the primary IPv6 address until the instance is terminated or the network interface is detached. For more information about primary IPv6 addresses, see RunInstances.
ena_srd_specification: Option<EnaSrdSpecificationRequest>Specifies the ENA Express settings for the network interface that's attached to the instance.
connection_tracking_specification: Option<ConnectionTrackingSpecificationRequest>A security group connection tracking specification that enables you to set the timeout for connection tracking on an Elastic network interface. For more information, see Connection tracking timeouts in the Amazon EC2 User Guide.
Implementations§
source§impl InstanceNetworkInterfaceSpecification
 
impl InstanceNetworkInterfaceSpecification
sourcepub fn associate_public_ip_address(&self) -> Option<bool>
 
pub fn associate_public_ip_address(&self) -> Option<bool>
Indicates whether to assign a public IPv4 address to an instance you launch in a VPC. The public IP address can only be assigned to a network interface for eth0, and can only be assigned to a new network interface, not an existing one. You cannot specify more than one network interface in the request. If launching into a default subnet, the default value is true.
Amazon Web Services charges for all public IPv4 addresses, including public IPv4 addresses associated with running instances and Elastic IP addresses. For more information, see the Public IPv4 Address tab on the Amazon VPC pricing page.
sourcepub fn delete_on_termination(&self) -> Option<bool>
 
pub fn delete_on_termination(&self) -> Option<bool>
If set to true, the interface is deleted when the instance is terminated. You can specify true only if creating a new network interface when launching an instance.
sourcepub fn description(&self) -> Option<&str>
 
pub fn description(&self) -> Option<&str>
The description of the network interface. Applies only if creating a network interface when launching an instance.
sourcepub fn device_index(&self) -> Option<i32>
 
pub fn device_index(&self) -> Option<i32>
The position of the network interface in the attachment order. A primary network interface has a device index of 0.
If you specify a network interface when launching an instance, you must specify the device index.
sourcepub fn groups(&self) -> &[String]
 
pub fn groups(&self) -> &[String]
The IDs of the security groups for the network interface. Applies only if creating a network interface when launching an instance.
If no value was sent for this field, a default will be set. If you want to determine if no value was sent, use .groups.is_none().
sourcepub fn ipv6_address_count(&self) -> Option<i32>
 
pub fn ipv6_address_count(&self) -> Option<i32>
A number of IPv6 addresses to assign to the network interface. Amazon EC2 chooses the IPv6 addresses from the range of the subnet. You cannot specify this option and the option to assign specific IPv6 addresses in the same request. You can specify this option if you've specified a minimum number of instances to launch.
sourcepub fn ipv6_addresses(&self) -> &[InstanceIpv6Address]
 
pub fn ipv6_addresses(&self) -> &[InstanceIpv6Address]
The IPv6 addresses to assign to the network interface. You cannot specify this option and the option to assign a number of IPv6 addresses in the same request. You cannot specify this option if you've specified a minimum number of instances to launch.
If no value was sent for this field, a default will be set. If you want to determine if no value was sent, use .ipv6_addresses.is_none().
sourcepub fn network_interface_id(&self) -> Option<&str>
 
pub fn network_interface_id(&self) -> Option<&str>
The ID of the network interface.
If you are creating a Spot Fleet, omit this parameter because you can’t specify a network interface ID in a launch specification.
sourcepub fn private_ip_address(&self) -> Option<&str>
 
pub fn private_ip_address(&self) -> Option<&str>
The private IPv4 address of the network interface. Applies only if creating a network interface when launching an instance. You cannot specify this option if you're launching more than one instance in a RunInstances request.
sourcepub fn private_ip_addresses(&self) -> &[PrivateIpAddressSpecification]
 
pub fn private_ip_addresses(&self) -> &[PrivateIpAddressSpecification]
The private IPv4 addresses to assign to the network interface. Only one private IPv4 address can be designated as primary. You cannot specify this option if you're launching more than one instance in a RunInstances request.
If no value was sent for this field, a default will be set. If you want to determine if no value was sent, use .private_ip_addresses.is_none().
sourcepub fn secondary_private_ip_address_count(&self) -> Option<i32>
 
pub fn secondary_private_ip_address_count(&self) -> Option<i32>
The number of secondary private IPv4 addresses. You can't specify this option and specify more than one private IP address using the private IP addresses option. You cannot specify this option if you're launching more than one instance in a RunInstances request.
sourcepub fn subnet_id(&self) -> Option<&str>
 
pub fn subnet_id(&self) -> Option<&str>
The ID of the subnet associated with the network interface. Applies only if creating a network interface when launching an instance.
sourcepub fn associate_carrier_ip_address(&self) -> Option<bool>
 
pub fn associate_carrier_ip_address(&self) -> Option<bool>
Indicates whether to assign a carrier IP address to the network interface.
You can only assign a carrier IP address to a network interface that is in a subnet in a Wavelength Zone. For more information about carrier IP addresses, see Carrier IP address in the Amazon Web Services Wavelength Developer Guide.
sourcepub fn interface_type(&self) -> Option<&str>
 
pub fn interface_type(&self) -> Option<&str>
The type of network interface.
Valid values: interface | efa
sourcepub fn network_card_index(&self) -> Option<i32>
 
pub fn network_card_index(&self) -> Option<i32>
The index of the network card. Some instance types support multiple network cards. The primary network interface must be assigned to network card index 0. The default is network card index 0.
If you are using RequestSpotInstances to create Spot Instances, omit this parameter because you can’t specify the network card index when using this API. To specify the network card index, use RunInstances.
sourcepub fn ipv4_prefixes(&self) -> &[Ipv4PrefixSpecificationRequest]
 
pub fn ipv4_prefixes(&self) -> &[Ipv4PrefixSpecificationRequest]
The IPv4 delegated prefixes to be assigned to the network interface. You cannot use this option if you use the Ipv4PrefixCount option.
If no value was sent for this field, a default will be set. If you want to determine if no value was sent, use .ipv4_prefixes.is_none().
sourcepub fn ipv4_prefix_count(&self) -> Option<i32>
 
pub fn ipv4_prefix_count(&self) -> Option<i32>
The number of IPv4 delegated prefixes to be automatically assigned to the network interface. You cannot use this option if you use the Ipv4Prefix option.
sourcepub fn ipv6_prefixes(&self) -> &[Ipv6PrefixSpecificationRequest]
 
pub fn ipv6_prefixes(&self) -> &[Ipv6PrefixSpecificationRequest]
The IPv6 delegated prefixes to be assigned to the network interface. You cannot use this option if you use the Ipv6PrefixCount option.
If no value was sent for this field, a default will be set. If you want to determine if no value was sent, use .ipv6_prefixes.is_none().
sourcepub fn ipv6_prefix_count(&self) -> Option<i32>
 
pub fn ipv6_prefix_count(&self) -> Option<i32>
The number of IPv6 delegated prefixes to be automatically assigned to the network interface. You cannot use this option if you use the Ipv6Prefix option.
sourcepub fn primary_ipv6(&self) -> Option<bool>
 
pub fn primary_ipv6(&self) -> Option<bool>
The primary IPv6 address of the network interface. When you enable an IPv6 GUA address to be a primary IPv6, the first IPv6 GUA will be made the primary IPv6 address until the instance is terminated or the network interface is detached. For more information about primary IPv6 addresses, see RunInstances.
sourcepub fn ena_srd_specification(&self) -> Option<&EnaSrdSpecificationRequest>
 
pub fn ena_srd_specification(&self) -> Option<&EnaSrdSpecificationRequest>
Specifies the ENA Express settings for the network interface that's attached to the instance.
sourcepub fn connection_tracking_specification(
    &self,
) -> Option<&ConnectionTrackingSpecificationRequest>
 
pub fn connection_tracking_specification( &self, ) -> Option<&ConnectionTrackingSpecificationRequest>
A security group connection tracking specification that enables you to set the timeout for connection tracking on an Elastic network interface. For more information, see Connection tracking timeouts in the Amazon EC2 User Guide.
source§impl InstanceNetworkInterfaceSpecification
 
impl InstanceNetworkInterfaceSpecification
sourcepub fn builder() -> InstanceNetworkInterfaceSpecificationBuilder
 
pub fn builder() -> InstanceNetworkInterfaceSpecificationBuilder
Creates a new builder-style object to manufacture InstanceNetworkInterfaceSpecification.
Trait Implementations§
source§impl Clone for InstanceNetworkInterfaceSpecification
 
impl Clone for InstanceNetworkInterfaceSpecification
source§fn clone(&self) -> InstanceNetworkInterfaceSpecification
 
fn clone(&self) -> InstanceNetworkInterfaceSpecification
1.0.0 · source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moresource§impl PartialEq for InstanceNetworkInterfaceSpecification
 
impl PartialEq for InstanceNetworkInterfaceSpecification
source§fn eq(&self, other: &InstanceNetworkInterfaceSpecification) -> bool
 
fn eq(&self, other: &InstanceNetworkInterfaceSpecification) -> bool
self and other values to be equal, and is used
by ==.impl StructuralPartialEq for InstanceNetworkInterfaceSpecification
Auto Trait Implementations§
impl Freeze for InstanceNetworkInterfaceSpecification
impl RefUnwindSafe for InstanceNetworkInterfaceSpecification
impl Send for InstanceNetworkInterfaceSpecification
impl Sync for InstanceNetworkInterfaceSpecification
impl Unpin for InstanceNetworkInterfaceSpecification
impl UnwindSafe for InstanceNetworkInterfaceSpecification
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
source§impl<T> Instrument for T
 
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
 
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
 
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
 
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more