Skip to content

Commit de49ec9

Browse files
authored
Dynamically set availability zone count using instance count and subnet count (#16)
1 parent bd8cf4d commit de49ec9

File tree

1 file changed

+6
-4
lines changed

1 file changed

+6
-4
lines changed

opensearch.tf

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,9 @@
11
data "aws_availability_zones" "available" {}
22

33
locals {
4-
region = data.aws_region.current.name
5-
name = "es-${var.es_application_name}"
4+
region = data.aws_region.current.name
5+
name = "es-${var.es_application_name}"
6+
ideal_subnet_count = var.es_instance_count > 2 ? min(length(module.network.private_subnet_ids), 3) : var.es_instance_count
67
}
78

89
resource "aws_iam_service_linked_role" "elasticsearch" {
@@ -58,7 +59,7 @@ module "opensearch" {
5859
instance_type = coalesce(var.es_instance_type, var.es_dedicated_master_type)
5960

6061
zone_awareness_config = {
61-
availability_zone_count = length(module.network.private_subnet_ids) > 3 ? 3 : length(module.network.private_subnet_ids)
62+
availability_zone_count = local.ideal_subnet_count
6263
}
6364

6465
zone_awareness_enabled = true
@@ -101,7 +102,8 @@ module "opensearch" {
101102
}
102103

103104
vpc_options = {
104-
subnet_ids = length(module.network.private_subnet_ids) > 3 ? slice(module.network.private_subnet_ids, 0, 3) : module.network.private_subnet_ids
105+
subnet_ids = slice(module.network.private_subnet_ids, 0, min(length(module.network.private_subnet_ids), local.ideal_subnet_count))
106+
105107
}
106108

107109
# Security Group rule example

0 commit comments

Comments
 (0)