terraform/modules/hana-scaleout-standby/locals.tf (95 lines of code) (raw):

# Copyright 2021 Google LLC # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # https://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. locals { pd_ssd_map = { "n1-highmem-32" = 834 "n1-highmem-64" = 1280 "n1-highmem-96" = 1904 "n2-highmem-32" = 834 "n2-highmem-48" = 1184 "n2-highmem-64" = 1568 "n2-highmem-80" = 1952 "m1-megamem-96" = 3717 "m1-ultramem-40" = 2914 "m1-ultramem-80" = 4451 "m1-ultramem-160" = 7334 "m2-ultramem-208" = 10400 "m2-ultramem-416" = 19217 } pd_hdd_map = { "n1-highmem-32" = 448 "n1-highmem-64" = 864 "n1-highmem-96" = 1280 "n2-highmem-32" = 544 "n2-highmem-48" = 800 "n2-highmem-64" = 1056 "n2-highmem-80" = 1312 "m1-megamem-96" = 2898 "m1-ultramem-40" = 1954 "m1-ultramem-80" = 3876 "m1-ultramem-160" = 7720 "m2-ultramem-208" = 11808 "m2-ultramem-416" = 23564 } pd_balanced_map = { "n1-highmem-32" = 1429 "n1-highmem-64" = 1980 "n1-highmem-96" = 2942 "n2-highmem-32" = 1429 "n2-highmem-48" = 1831 "n2-highmem-64" = 2424 "n2-highmem-80" = 3017 "m1-megamem-96" = 4286 "m1-ultramem-40" = 4286 "m1-ultramem-80" = 4286 "m1-ultramem-160" = 6180 "m2-ultramem-208" = 8667 "m2-ultramem-416" = 15766 } instance_mem_map = { "n1-highmem-32" = 208 "n1-highmem-64" = 416 "n1-highmem-96" = 624 "n2-highmem-32" = 256 "n2-highmem-48" = 384 "n2-highmem-64" = 512 "n2-highmem-80" = 640 "m1-megamem-96" = 1433 "m1-ultramem-40" = 961 "m1-ultramem-80" = 1922 "m1-ultramem-160" = 3844 "m2-ultramem-208" = 5888 "m2-ultramem-416" = 11766 } hana_log_size = min(512, max(64, lookup(local.instance_mem_map, var.instance_type) / 2)) hana_data_size = lookup(local.instance_mem_map, var.instance_type) * 15 / 10 #hana_shared_size = min(1024, lookup(local.instance_mem_map, var.instance_type)) hana_usr_size = 32 #hana_backup_size = lookup(local.instance_mem_map, var.instance_type) * 2 #pd_ssd_size = max(lookup(local.pd_ssd_map, var.instance_type), (local.hana_log_size + local.hana_data_size + local.hana_shared_size + local.hana_usr_size)) pd_ssd_size = max(lookup(local.pd_ssd_map, var.instance_type), (local.hana_log_size + local.hana_data_size + local.hana_usr_size)) pd_bal_size = max(lookup(local.pd_balanced_map, var.instance_type), (local.hana_log_size + local.hana_data_size + local.hana_usr_size)) #pd_hdd_size = local.hana_backup_size pd_ssd_size_worker = local.hana_log_size + local.hana_data_size + local.hana_usr_size + 1 region = join("-", slice(split("-", var.zone), 0, 2)) subnetwork_project = var.subnetwork_project == "" ? var.project_id : var.subnetwork_project network_parts = split("/", data.google_compute_subnetwork.subnetwork.network) network = element(local.network_parts, length(local.network_parts) - 1) sap_node_count = var.instance_count_worker + var.instance_count_standby master_inventory = [{ host = join("", google_compute_address.gcp_sap_hana_intip_master.*.address), groups = ["hana"], vars = { sap_hana_is_master = true, }, }] standby_inventory = [{ host = join("", google_compute_address.gcp_sap_hana_intip_standby.*.address), groups = ["hana"], vars = { sap_hana_is_standby = true, }, }] worker_inventory = [for ip in google_compute_address.gcp_sap_hana_intip_worker : { host = ip.address, groups = ["hana"], vars = { sap_hana_is_worker = true, }, }] inventory = concat(local.master_inventory, local.standby_inventory, local.worker_inventory) }