Constructor and Description |
---|
Builder() |
public VpcProps.Builder cidr(java.lang.String cidr)
VpcProps.getCidr()
cidr
- The CIDR range to use for the VPC, e.g. '10.0.0.0/16'.
Should be a minimum of /28 and maximum size of /16. The range will be
split across all subnets per Availability Zone.this
public VpcProps.Builder defaultInstanceTenancy(DefaultInstanceTenancy defaultInstanceTenancy)
VpcProps.getDefaultInstanceTenancy()
defaultInstanceTenancy
- The default tenancy of instances launched into the VPC.
By setting this to dedicated tenancy, instances will be launched on
hardware dedicated to a single AWS customer, unless specifically specified
at instance launch time. Please note, not all instance types are usable
with Dedicated tenancy.this
public VpcProps.Builder enableDnsHostnames(java.lang.Boolean enableDnsHostnames)
VpcProps.getEnableDnsHostnames()
enableDnsHostnames
- Indicates whether the instances launched in the VPC get public DNS hostnames.
If this attribute is true, instances in the VPC get public DNS hostnames,
but only if the enableDnsSupport attribute is also set to true.this
public VpcProps.Builder enableDnsSupport(java.lang.Boolean enableDnsSupport)
VpcProps.getEnableDnsSupport()
enableDnsSupport
- Indicates whether the DNS resolution is supported for the VPC.
If this attribute is false, the Amazon-provided DNS server in the VPC that
resolves public DNS hostnames to IP addresses is not enabled. If this
attribute is true, queries to the Amazon provided DNS server at the
169.254.169.253 IP address, or the reserved IP address at the base of the
VPC IPv4 network range plus two will succeed.this
public VpcProps.Builder flowLogs(java.util.Map<java.lang.String,? extends FlowLogOptions> flowLogs)
VpcProps.getFlowLogs()
flowLogs
- Flow logs to add to this VPC.this
public VpcProps.Builder gatewayEndpoints(java.util.Map<java.lang.String,? extends GatewayVpcEndpointOptions> gatewayEndpoints)
VpcProps.getGatewayEndpoints()
gatewayEndpoints
- Gateway endpoints to add to this VPC.this
public VpcProps.Builder maxAzs(java.lang.Number maxAzs)
VpcProps.getMaxAzs()
maxAzs
- Define the maximum number of AZs to use in this region.
If the region has more AZs than you want to use (for example, because of
EIP limits), pick a lower number here. The AZs will be sorted and picked
from the start of the list.
If you pick a higher number than the number of AZs in the region, all AZs in the region will be selected. To use "all AZs" available to your account, use a high number (such as 99).
Be aware that environment-agnostic stacks will be created with access to only 2 AZs, so to use more than 2 AZs, be sure to specify the account and region on your stack.
this
public VpcProps.Builder natGatewayProvider(NatProvider natGatewayProvider)
VpcProps.getNatGatewayProvider()
natGatewayProvider
- What type of NAT provider to use.
Select between NAT gateways or NAT instances. NAT gateways
may not be available in all AWS regions.this
public VpcProps.Builder natGateways(java.lang.Number natGateways)
VpcProps.getNatGateways()
natGateways
- The number of NAT Gateways/Instances to create.
The type of NAT gateway or instance will be determined by the
natGatewayProvider
parameter.
You can set this number lower than the number of Availability Zones in your VPC in order to save on NAT cost. Be aware you may be charged for cross-AZ data traffic instead.
this
public VpcProps.Builder natGatewaySubnets(SubnetSelection natGatewaySubnets)
VpcProps.getNatGatewaySubnets()
natGatewaySubnets
- Configures the subnets which will have NAT Gateways/Instances.
You can pick a specific group of subnets by specifying the group name;
the picked subnets must be public subnets.
Only necessary if you have more than one public subnet group.
this
public VpcProps.Builder subnetConfiguration(java.util.List<? extends SubnetConfiguration> subnetConfiguration)
VpcProps.getSubnetConfiguration()
subnetConfiguration
- Configure the subnets to build for each AZ.
Each entry in this list configures a Subnet Group; each group will contain a
subnet for each Availability Zone.
For example, if you want 1 public subnet, 1 private subnet, and 1 isolated subnet in each AZ provide the following:
Vpc.Builder.create(this, "VPC") .subnetConfiguration(List.of(SubnetConfiguration.builder() .cidrMask(24) .name("ingress") .subnetType(SubnetType.PUBLIC) .build(), SubnetConfiguration.builder() .cidrMask(24) .name("application") .subnetType(SubnetType.PRIVATE_WITH_NAT) .build(), SubnetConfiguration.builder() .cidrMask(28) .name("rds") .subnetType(SubnetType.PRIVATE_ISOLATED) .build())) .build();
this
public VpcProps.Builder vpcName(java.lang.String vpcName)
VpcProps.getVpcName()
vpcName
- The VPC name.
Since the VPC resource doesn't support providing a physical name, the value provided here will be recorded in the Name
tagthis
public VpcProps.Builder vpnConnections(java.util.Map<java.lang.String,? extends VpnConnectionOptions> vpnConnections)
VpcProps.getVpnConnections()
vpnConnections
- VPN connections to this VPC.this
public VpcProps.Builder vpnGateway(java.lang.Boolean vpnGateway)
VpcProps.getVpnGateway()
vpnGateway
- Indicates whether a VPN gateway should be created and attached to this VPC.this
public VpcProps.Builder vpnGatewayAsn(java.lang.Number vpnGatewayAsn)
VpcProps.getVpnGatewayAsn()
vpnGatewayAsn
- The private Autonomous System Number (ASN) for the VPN gateway.this
public VpcProps.Builder vpnRoutePropagation(java.util.List<? extends SubnetSelection> vpnRoutePropagation)
VpcProps.getVpnRoutePropagation()
vpnRoutePropagation
- Where to propagate VPN routes.this