#[non_exhaustive]pub struct LaunchTemplateInstanceNetworkInterfaceSpecificationRequest {Show 22 fields
    pub associate_carrier_ip_address: Option<bool>,
    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 interface_type: Option<String>,
    pub ipv6_address_count: Option<i32>,
    pub ipv6_addresses: Option<Vec<InstanceIpv6AddressRequest>>,
    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 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
The parameters for 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_carrier_ip_address: Option<bool>Associates a Carrier IP address with eth0 for a new network interface.
Use this option when you launch an instance in a Wavelength Zone and want to associate a Carrier IP address with the network interface. For more information about Carrier IP addresses, see Carrier IP addresses in the Wavelength Developer Guide.
associate_public_ip_address: Option<bool>Associates a public IPv4 address with eth0 for a new network interface.
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>Indicates whether the network interface is deleted when the instance is terminated.
description: Option<String>A description for the network interface.
device_index: Option<i32>The device index for the network interface attachment. Each network interface requires a device index. If you create a launch template that includes secondary network interfaces but not a primary network interface, then you must add a primary network interface as a launch parameter when you launch an instance from the template.
groups: Option<Vec<String>>The IDs of one or more security groups.
interface_type: Option<String>The type of network interface. To create an Elastic Fabric Adapter (EFA), specify efa. For more information, see Elastic Fabric Adapter in the Amazon Elastic Compute Cloud User Guide.
If you are not creating an EFA, specify interface or omit this parameter.
Valid values: interface | efa
ipv6_address_count: Option<i32>The number of IPv6 addresses to assign to a network interface. Amazon EC2 automatically selects the IPv6 addresses from the subnet range. You can't use this option if specifying specific IPv6 addresses.
ipv6_addresses: Option<Vec<InstanceIpv6AddressRequest>>One or more specific IPv6 addresses from the IPv6 CIDR block range of your subnet. You can't use this option if you're specifying a number of IPv6 addresses.
network_interface_id: Option<String>The ID of the network interface.
private_ip_address: Option<String>The primary private IPv4 address of the network interface.
private_ip_addresses: Option<Vec<PrivateIpAddressSpecification>>One or more private IPv4 addresses.
secondary_private_ip_address_count: Option<i32>The number of secondary private IPv4 addresses to assign to a network interface.
subnet_id: Option<String>The ID of the subnet for the network interface.
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.
ipv4_prefixes: Option<Vec<Ipv4PrefixSpecificationRequest>>One or more IPv4 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 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>>One or more IPv6 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 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>Configure ENA Express settings for your launch template.
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 Elastic Compute Cloud User Guide.
Implementations§
source§impl LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
 
impl LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
sourcepub fn associate_carrier_ip_address(&self) -> Option<bool>
 
pub fn associate_carrier_ip_address(&self) -> Option<bool>
Associates a Carrier IP address with eth0 for a new network interface.
Use this option when you launch an instance in a Wavelength Zone and want to associate a Carrier IP address with the network interface. For more information about Carrier IP addresses, see Carrier IP addresses in the Wavelength Developer Guide.
sourcepub fn associate_public_ip_address(&self) -> Option<bool>
 
pub fn associate_public_ip_address(&self) -> Option<bool>
Associates a public IPv4 address with eth0 for a new network interface.
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>
Indicates whether the network interface is deleted when the instance is terminated.
sourcepub fn description(&self) -> Option<&str>
 
pub fn description(&self) -> Option<&str>
A description for the network interface.
sourcepub fn device_index(&self) -> Option<i32>
 
pub fn device_index(&self) -> Option<i32>
The device index for the network interface attachment. Each network interface requires a device index. If you create a launch template that includes secondary network interfaces but not a primary network interface, then you must add a primary network interface as a launch parameter when you launch an instance from the template.
sourcepub fn groups(&self) -> &[String]
 
pub fn groups(&self) -> &[String]
The IDs of one or more security groups.
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 interface_type(&self) -> Option<&str>
 
pub fn interface_type(&self) -> Option<&str>
The type of network interface. To create an Elastic Fabric Adapter (EFA), specify efa. For more information, see Elastic Fabric Adapter in the Amazon Elastic Compute Cloud User Guide.
If you are not creating an EFA, specify interface or omit this parameter.
Valid values: interface | efa
sourcepub fn ipv6_address_count(&self) -> Option<i32>
 
pub fn ipv6_address_count(&self) -> Option<i32>
The number of IPv6 addresses to assign to a network interface. Amazon EC2 automatically selects the IPv6 addresses from the subnet range. You can't use this option if specifying specific IPv6 addresses.
sourcepub fn ipv6_addresses(&self) -> &[InstanceIpv6AddressRequest]
 
pub fn ipv6_addresses(&self) -> &[InstanceIpv6AddressRequest]
One or more specific IPv6 addresses from the IPv6 CIDR block range of your subnet. You can't use this option if you're specifying a number of IPv6 addresses.
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.
sourcepub fn private_ip_address(&self) -> Option<&str>
 
pub fn private_ip_address(&self) -> Option<&str>
The primary private IPv4 address of the network interface.
sourcepub fn private_ip_addresses(&self) -> &[PrivateIpAddressSpecification]
 
pub fn private_ip_addresses(&self) -> &[PrivateIpAddressSpecification]
One or more private IPv4 addresses.
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 to assign to a network interface.
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.
sourcepub fn ipv4_prefixes(&self) -> &[Ipv4PrefixSpecificationRequest]
 
pub fn ipv4_prefixes(&self) -> &[Ipv4PrefixSpecificationRequest]
One or more IPv4 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 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]
One or more IPv6 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 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>
Configure ENA Express settings for your launch template.
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 Elastic Compute Cloud User Guide.
source§impl LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
 
impl LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
sourcepub fn builder(
) -> LaunchTemplateInstanceNetworkInterfaceSpecificationRequestBuilder
 
pub fn builder( ) -> LaunchTemplateInstanceNetworkInterfaceSpecificationRequestBuilder
Creates a new builder-style object to manufacture LaunchTemplateInstanceNetworkInterfaceSpecificationRequest.
Trait Implementations§
source§impl Clone for LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
 
impl Clone for LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
source§fn clone(&self) -> LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
 
fn clone(&self) -> LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
1.0.0 · source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moresource§impl PartialEq for LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
 
impl PartialEq for LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
source§fn eq(
    &self,
    other: &LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
) -> bool
 
fn eq( &self, other: &LaunchTemplateInstanceNetworkInterfaceSpecificationRequest ) -> bool
self and other values to be equal, and is used
by ==.impl StructuralPartialEq for LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
Auto Trait Implementations§
impl Freeze for LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
impl RefUnwindSafe for LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
impl Send for LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
impl Sync for LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
impl Unpin for LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
impl UnwindSafe for LaunchTemplateInstanceNetworkInterfaceSpecificationRequest
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