mws_vpc_egress_nat (Resource)
Egress (Many-to-Many) NAT-шлюз — механизм, при котором несколько внутренних IP-адресов сопоставляются с одним или несколькими внешними IP-адресами
Пример использования
terraform
resource "mws_vpc_network" "network" {
network = var.network_name
}
resource "mws_vpc_subnet" "subnet" {
subnet = var.subnet_name
network = mws_vpc_network.network.network
cidr = var.subnet_cidr
}
resource "mws_vpc_external_address" "external_address" {
external_address = var.external_address_name
}
resource "mws_vpc_egress_nat" "example_egress_nat" {
egress_nat = "example-egress-nat"
network = mws_vpc_network.network.network
metadata = {
description = "This is an example Egress NAT resource"
display_name = "Example Egress NAT"
}
external = {
addresses = [
{
ref = mws_vpc_external_address.external_address.metadata.id
}
]
}
internal = {
subnets = [mws_vpc_subnet.subnet.metadata.id]
}
pba = {
block_size = 64
blocks_per_client = 10
}
}
variable "network_name" {
type = string
default = "my-network"
description = "VPC network name"
}
variable "subnet_name" {
type = string
default = "my-subnet"
description = "Base name for subnets"
}
variable "subnet_cidr" {
type = string
default = "192.168.0.0/17"
description = "CIDR for subnet"
}
variable "external_address_name" {
type = string
default = "my-test-external-address"
description = "External address name"
}Schema
Required
egress_nat(String) Имя Egress NATexternal(Attributes) Группирующий элемент для всего, что касается внешней части (ресурсов, доступных извне). (see below for nested schema)internal(Attributes) Группирующий элемент для всего, что касается внутренних ресурсов. (see below for nested schema)network(String) Имя сети
Optional
kind(String)metadata(Attributes) Набор общих для всех пользовательских объектов атрибутов. Может быть расширен атрибутами, специфичными для контейнеров. (see below for nested schema)pba(Attributes) Описывает настройки управления портами (Port Block Allocation). (see below for nested schema)port_allocation(Attributes) Описывает настройки управления портами. (see below for nested schema)project(String) Путь к проектуtimeouts(Attributes) (see below for nested schema)
Read-Only
id(String) The ID of this resource.status(Attributes) Описывает статус Egress (Many-to-Many) NAT-шлюза. (see below for nested schema)
Nested Schema for external
Required:
addresses(Attributes List) Список спецификаций внешних адресов, через которых будет осуществляться трансляция. (see below for nested schema)
Nested Schema for external.addresses
Optional:
ref(String) Относительная ссылка на статический внешний адрес.
Nested Schema for internal
Required:
subnets(List of String) Коллекция относительных ссылок на подсети, для которых будет осуществляться трансляция.
Nested Schema for metadata
Optional:
description(String) Описание ресурсаdisplay_name(String) Отображаемое имя свойстваname(String, Deprecated) Обязательное уникальное, глобально или в пределах проекта, имя. Используется в качестве части составного идентификатора объекта.
Read-Only:
create_time(String) Дата создания объектаdelete_time(String) Время запроса на удаление ресурсаid(String) ID свойстваpurge_time(String) Время удаления ресурсаusages(Attributes List) Связи с другими ресурсами. В зависимости от типа связи, операции над ресурсом могут быть ограничены (see below for nested schema)
Nested Schema for metadata.usages
Read-Only:
name(String) Имя связи, требуется для модификации коллекцииresource(String) Ссылка на ресурсusage_type(String) Тип связи. Помимо стандартных own и use могут быть добавлены специализированные типы для конкретных сервисов
Nested Schema for pba
Optional:
block_size(Number) Размер блока портов.blocks_per_client(Number) Максимальное количество блоков портов для одного клиента.
Nested Schema for port_allocation
Required:
ports_per_client(String) Диапазон количества портов, которые может использовать один клиент.
Nested Schema for timeouts
Optional:
create(String) A string that can be parsed as a duration consisting of numbers and unit suffixes, such as "30s" or "2h45m". Valid time units are "s" (seconds), "m" (minutes), "h" (hours).delete(String) A string that can be parsed as a duration consisting of numbers and unit suffixes, such as "30s" or "2h45m". Valid time units are "s" (seconds), "m" (minutes), "h" (hours). Setting a timeout for a Delete operation is only applicable if changes are saved into state before the destroy operation occurs.update(String) A string that can be parsed as a duration consisting of numbers and unit suffixes, such as "30s" or "2h45m". Valid time units are "s" (seconds), "m" (minutes), "h" (hours).
Nested Schema for status
Read-Only:
external(Attributes) Группирующий элемент для всего что, касается внешней части (ресурсов, доступных извне). (see below for nested schema)pba(Attributes) Описывает настройки управления портами (Port Block Allocation). (see below for nested schema)port_allocation(Attributes) Описывает примененные настройки управления портами. (see below for nested schema)ready(Attributes) Информация о статусе реконсиляции (see below for nested schema)
Nested Schema for status.external
Read-Only:
addresses(Attributes List) Список спецификаций внешних адресов, через которых будет осуществляться трансляция. (see below for nested schema)
Nested Schema for status.external.addresses
Read-Only:
ip_address(String) Значение IP адреса.ref(String) Относительная ссылка на статический адрес.
Nested Schema for status.pba
Read-Only:
block_size(Number) Размер блока портов.
Nested Schema for status.port_allocation
Read-Only:
ports_per_client(String) Диапазон количества портов, которые может использовать один клиент.
Nested Schema for status.ready
Read-Only:
message(String) Описание статусаstate(String) Состояние ресурса