Difference between revisions of "Terraform module: vpc"

From wikieduonline
Jump to navigation Jump to search
Line 74: Line 74:
 
   }
 
   }
 
  }
 
  }
 +
 +
== Resources: 76 ==
 +
<pre>
 +
aws_cloudwatch_log_group.flow_log
 +
aws_customer_gateway.this
 +
aws_db_subnet_group.database
 +
aws_default_network_acl.this
 +
aws_default_route_table.default
 +
aws_default_security_group.this
 +
aws_default_vpc.this
 +
aws_egress_only_internet_gateway.this
 +
aws_eip.nat
 +
aws_elasticache_subnet_group.elasticache
 +
aws_flow_log.this
 +
aws_iam_policy.vpc_flow_log_cloudwatch
 +
aws_iam_role.vpc_flow_log_cloudwatch
 +
aws_iam_role_policy_attachment.vpc_flow_log_cloudwatch
 +
aws_internet_gateway.this
 +
aws_nat_gateway.this
 +
aws_network_acl.database
 +
aws_network_acl.elasticache
 +
aws_network_acl.intra
 +
aws_network_acl.outpost
 +
aws_network_acl.private
 +
aws_network_acl.public
 +
aws_network_acl.redshift
 +
aws_network_acl_rule.database_inbound
 +
aws_network_acl_rule.database_outbound
 +
aws_network_acl_rule.elasticache_inbound
 +
aws_network_acl_rule.elasticache_outbound
 +
aws_network_acl_rule.intra_inbound
 +
aws_network_acl_rule.intra_outbound
 +
aws_network_acl_rule.outpost_inbound
 +
aws_network_acl_rule.outpost_outbound
 +
aws_network_acl_rule.private_inbound
 +
aws_network_acl_rule.private_outbound
 +
aws_network_acl_rule.public_inbound
 +
aws_network_acl_rule.public_outbound
 +
aws_network_acl_rule.redshift_inbound
 +
aws_network_acl_rule.redshift_outbound
 +
aws_redshift_subnet_group.redshift
 +
 +
aws_route.database_internet_gateway
 +
aws_route.database_ipv6_egress
 +
aws_route.database_nat_gateway
 +
aws_route.private_ipv6_egress
 +
aws_route.private_nat_gateway
 +
aws_route.public_internet_gateway
 +
aws_route.public_internet_gateway_ipv6
 +
aws_route_table.database
 +
aws_route_table.elasticache
 +
aws_route_table.intra
 +
aws_route_table.private
 +
aws_route_table.public
 +
aws_route_table.redshift
 +
aws_route_table_association.database
 +
aws_route_table_association.elasticache
 +
aws_route_table_association.intra
 +
aws_route_table_association.outpost
 +
aws_route_table_association.private
 +
aws_route_table_association.public
 +
aws_route_table_association.redshift
 +
aws_route_table_association.redshift_public
 +
 +
aws_subnet.database
 +
aws_subnet.elasticache
 +
aws_subnet.intra
 +
aws_subnet.outpost
 +
aws_subnet.private
 +
aws_subnet.public
 +
aws_subnet.redshift
 +
 +
[[aws_vpc]].this
 +
aws_vpc_dhcp_options.this
 +
aws_vpc_dhcp_options_association.this
 +
aws_vpc_endpoint.this
 +
aws_vpc_ipv4_cidr_block_association.this
 +
aws_vpn_gateway.this
 +
aws_vpn_gateway_attachment.this
 +
aws_vpn_gateway_route_propagation.intra
 +
aws_vpn_gateway_route_propagation.private
 +
aws_vpn_gateway_route_propagation.public
  
 
== Related ==
 
== Related ==

Revision as of 14:33, 29 June 2022

Official example

module "vpc" {
 source = "terraform-aws-modules/vpc/aws"

 name = "my-vpc"
 cidr = "10.0.0.0/16"

 azs             = ["eu-west-1a", "eu-west-1b", "eu-west-1c"]
 private_subnets = ["10.0.1.0/24", "10.0.2.0/24", "10.0.3.0/24"]
 public_subnets  = ["10.0.101.0/24", "10.0.102.0/24", "10.0.103.0/24"]

 enable_nat_gateway = true
 enable_vpn_gateway = true

 tags = {
   Terraform = "true"
   Environment = "dev"
 }
}

Additional examples

module "vpc" {
  source  = "terraform-aws-modules/vpc/aws"
  version = "3.2.0"

  name                 = "education-vpc"
  cidr                 = "10.0.0.0/16"
  azs                  = data.aws_availability_zones.available.names
  private_subnets      = ["10.0.1.0/24", "10.0.2.0/24", "10.0.3.0/24"]
  public_subnets       = ["10.0.4.0/24", "10.0.5.0/24", "10.0.6.0/24"]
  enable_nat_gateway   = true
  single_nat_gateway   = true
  enable_dns_hostnames = true 

  tags = {
    "kubernetes.io/cluster/${local.cluster_name}" = "shared"
  }

  public_subnet_tags = {
    "kubernetes.io/cluster/${local.cluster_name}" = "shared"
    "kubernetes.io/role/elb"                      = "1"
  }

  private_subnet_tags = {
    "kubernetes.io/cluster/${local.cluster_name}" = "shared"
    "kubernetes.io/role/internal-elb"             = "1"
  }
}


Simple 1 zone VPC with access to RDS

module "vpc" {
  source  = "terraform-aws-modules/vpc/aws"
  version = "3.2.0"

  name                 = "vpcsinglezone"
  cidr                 = "192.168.0.0/16"
  azs                  = eu-west-1a
  public_subnets       = ["192.168.0.0/24"]
  enable_nat_gateway   = true
  single_nat_gateway   = true
  enable_dns_hostnames = true 
  enable_dns_support   = true

  create_database_subnet_group           = true
  create_database_subnet_route_table     = true
  create_database_internet_gateway_route = true

  tags = {
    Terraform = "true"
    Environment = "dev"
  }
}

Resources: 76

 aws_cloudwatch_log_group.flow_log
 aws_customer_gateway.this
 aws_db_subnet_group.database
 aws_default_network_acl.this
 aws_default_route_table.default
 aws_default_security_group.this
 aws_default_vpc.this
 aws_egress_only_internet_gateway.this
 aws_eip.nat
 aws_elasticache_subnet_group.elasticache
 aws_flow_log.this
 aws_iam_policy.vpc_flow_log_cloudwatch
 aws_iam_role.vpc_flow_log_cloudwatch
 aws_iam_role_policy_attachment.vpc_flow_log_cloudwatch
 aws_internet_gateway.this
 aws_nat_gateway.this
 aws_network_acl.database
 aws_network_acl.elasticache
 aws_network_acl.intra
 aws_network_acl.outpost
 aws_network_acl.private
 aws_network_acl.public
 aws_network_acl.redshift
 aws_network_acl_rule.database_inbound
 aws_network_acl_rule.database_outbound
 aws_network_acl_rule.elasticache_inbound
 aws_network_acl_rule.elasticache_outbound
 aws_network_acl_rule.intra_inbound
 aws_network_acl_rule.intra_outbound
 aws_network_acl_rule.outpost_inbound
 aws_network_acl_rule.outpost_outbound
 aws_network_acl_rule.private_inbound
 aws_network_acl_rule.private_outbound
 aws_network_acl_rule.public_inbound
 aws_network_acl_rule.public_outbound
 aws_network_acl_rule.redshift_inbound
 aws_network_acl_rule.redshift_outbound
 aws_redshift_subnet_group.redshift

 aws_route.database_internet_gateway
 aws_route.database_ipv6_egress
 aws_route.database_nat_gateway
 aws_route.private_ipv6_egress
 aws_route.private_nat_gateway
 aws_route.public_internet_gateway
 aws_route.public_internet_gateway_ipv6
 aws_route_table.database
 aws_route_table.elasticache
 aws_route_table.intra
 aws_route_table.private
 aws_route_table.public
 aws_route_table.redshift
 aws_route_table_association.database
 aws_route_table_association.elasticache
 aws_route_table_association.intra
 aws_route_table_association.outpost
 aws_route_table_association.private
 aws_route_table_association.public
 aws_route_table_association.redshift
 aws_route_table_association.redshift_public

 aws_subnet.database
 aws_subnet.elasticache
 aws_subnet.intra
 aws_subnet.outpost
 aws_subnet.private
 aws_subnet.public
 aws_subnet.redshift

 aws_vpc.this
 aws_vpc_dhcp_options.this
 aws_vpc_dhcp_options_association.this
 aws_vpc_endpoint.this
 aws_vpc_ipv4_cidr_block_association.this
 aws_vpn_gateway.this
 aws_vpn_gateway_attachment.this
 aws_vpn_gateway_route_propagation.intra
 aws_vpn_gateway_route_propagation.private
 aws_vpn_gateway_route_propagation.public

Related

* Terraform resource: aws_vpc * AWS::EC2::VPC * db_subnet_group_name * database_subnets

See also

* AWS VPC, AWS default VPC, AWS VPC sharing, AWS subnets, Amazon VPC NAT gateway, Amazon VPN internet gateway, VPC Flow Logs, aws ec2 create-vpc, aws ec2 describe-vpcs, NACL, VPC Scenarios, AWS VPC endpoint, AWS ClassicLink, VPC peering, Reachability Analyzer, AWS internet gateway, VPC Lattice, vpce.amazonaws.com * Terraform AWS modules: vpc, rds, rds-aurora, cdn, EKS, IAM * Terraform modules, terraform get, module { source }, AWS modules, module., child modules, Terraform modules inputs, submodules, terraform init -upgrade

Advertising: