terraform/modules/hana-ha/main.tf (197 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
*
* http://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.
*/
module "sap_hana_template" {
source = "../terraform-google-vm//modules/instance_template"
machine_type = var.instance_type
project_id = var.project_id
region = local.region
metadata = {
ssh-keys = "${var.gce_ssh_user}:${file("${var.gce_ssh_pub_key_file}")}"
}
service_account = {
email = var.service_account_email
scopes = ["cloud-platform"]
}
labels = {
app = "hana"
}
subnetwork = var.subnetwork
subnetwork_project = var.subnetwork_project
tags = var.network_tags
can_ip_forward = true
source_image_family = var.source_image_family
source_image_project = var.source_image_project
disk_size_gb = var.boot_disk_size
disk_type = var.boot_disk_type
auto_delete = var.autodelete_disk
}
resource "google_compute_address" "gcp_sap_hana_intip_primary" {
name = "${local.instance_name_primary}-int"
address_type = "INTERNAL"
subnetwork = "projects/${var.subnetwork_project}/regions/${local.region}/subnetworks/${var.subnetwork}"
region = local.region
project = var.project_id
purpose = "GCE_ENDPOINT"
}
resource "google_compute_address" "gcp_sap_hana_intip_secondary" {
name = "${local.instance_name_secondary}-int"
address_type = "INTERNAL"
subnetwork = "projects/${var.subnetwork_project}/regions/${local.region}/subnetworks/${var.subnetwork}"
region = local.region
project = var.project_id
purpose = "GCE_ENDPOINT"
}
module "sap_hana_umig_primary" {
source = "../terraform-google-vm//modules/umig"
project_id = var.project_id
region = local.region
zone = var.primary_zone
subnetwork = var.subnetwork
subnetwork_project = var.subnetwork_project
static_ips = [google_compute_address.gcp_sap_hana_intip_primary.address]
hostname = local.instance_name_primary
auto_append_hostname = var.instance_name_primary == ""
num_instances = var.target_size
instance_template = module.sap_hana_template.self_link
}
module "sap_hana_umig_secondary" {
source = "../terraform-google-vm//modules/umig"
project_id = var.project_id
region = local.region
zone = var.secondary_zone
subnetwork = var.subnetwork
subnetwork_project = var.subnetwork_project
static_ips = [google_compute_address.gcp_sap_hana_intip_secondary.address]
hostname = local.instance_name_secondary
auto_append_hostname = var.instance_name_secondary == ""
num_instances = var.target_size
instance_template = module.sap_hana_template.self_link
}
resource "google_compute_disk" "gcp_sap_hana_data_primary" {
project = var.project_id
name = "${local.instance_name_primary}-data"
type = var.additional_disk_type
zone = var.primary_zone
size = var.additional_disk_type == "pd-ssd" ? local.pd_ssd_size : local.pd_bal_size
# Add the disk_encryption_key block only if a pd_kms_key was provided
dynamic "disk_encryption_key" {
for_each = var.pd_kms_key != "" ? [""] : []
content {
kms_key_self_link = var.pd_kms_key
}
}
}
resource "google_compute_disk" "gcp_sap_hana_backup_primary" {
project = var.project_id
name = "${local.instance_name_primary}-backup"
count = tobool(var.create_backup_volume) == true ? 1 : 0
type = "pd-standard"
zone = var.primary_zone
size = local.pd_hdd_size
# Add the disk_encryption_key block only if a pd_kms_key was provided
dynamic "disk_encryption_key" {
for_each = var.pd_kms_key != "" ? [""] : []
content {
kms_key_self_link = var.pd_kms_key
}
}
}
resource "google_compute_disk" "gcp_sap_hana_data_secondary" {
project = var.project_id
name = "${local.instance_name_secondary}-data"
type = var.additional_disk_type
zone = var.secondary_zone
size = var.additional_disk_type == "pd-ssd" ? local.pd_ssd_size : local.pd_bal_size
# Add the disk_encryption_key block only if a pd_kms_key was provided
dynamic "disk_encryption_key" {
for_each = var.pd_kms_key != "" ? [""] : []
content {
kms_key_self_link = var.pd_kms_key
}
}
}
resource "google_compute_disk" "gcp_sap_hana_backup_secondary" {
project = var.project_id
name = "${local.instance_name_secondary}-backup"
count = tobool(var.create_backup_volume) == true ? 1 : 0
type = "pd-standard"
zone = var.secondary_zone
size = local.pd_hdd_size
# Add the disk_encryption_key block only if a pd_kms_key was provided
dynamic "disk_encryption_key" {
for_each = var.pd_kms_key != "" ? [""] : []
content {
kms_key_self_link = var.pd_kms_key
}
}
}
resource "google_compute_attached_disk" "primary_data" {
disk = google_compute_disk.gcp_sap_hana_data_primary.id
instance = element(split("/", element(tolist(module.sap_hana_umig_primary.instances_self_links), 0)), 10)
device_name = "${element(split("/", element(tolist(module.sap_hana_umig_primary.instances_self_links), 0)), 10)}-data"
project = var.project_id
zone = var.primary_zone
}
resource "google_compute_attached_disk" "primary_backup" {
count = tobool(var.create_backup_volume) == true ? 1 : 0
disk = google_compute_disk.gcp_sap_hana_backup_primary[0].id
instance = element(split("/", element(tolist(module.sap_hana_umig_primary.instances_self_links), 0)), 10)
device_name = "${element(split("/", element(tolist(module.sap_hana_umig_primary.instances_self_links), 0)), 10)}-backup"
project = var.project_id
zone = var.primary_zone
}
resource "google_compute_attached_disk" "secondary_data" {
disk = google_compute_disk.gcp_sap_hana_data_secondary.id
instance = element(split("/", element(tolist(module.sap_hana_umig_secondary.instances_self_links), 0)), 10)
device_name = "${element(split("/", element(tolist(module.sap_hana_umig_secondary.instances_self_links), 0)), 10)}-data"
project = var.project_id
zone = var.secondary_zone
}
resource "google_compute_attached_disk" "secondary_backup" {
count = tobool(var.create_backup_volume) == true ? 1 : 0
disk = google_compute_disk.gcp_sap_hana_backup_secondary[0].id
instance = element(split("/", element(tolist(module.sap_hana_umig_secondary.instances_self_links), 0)), 10)
device_name = "${element(split("/", element(tolist(module.sap_hana_umig_secondary.instances_self_links), 0)), 10)}-backup"
project = var.project_id
zone = var.secondary_zone
}
module "sap_hana_ilb" {
source = "../terraform-google-lb-internal"
project = var.project_id
region = local.region
network = local.network
network_project = var.subnetwork_project
subnetwork = var.subnetwork
name = local.ilb_name
source_tags = ["source-tag"]
target_tags = ["target-tag"]
ports = null
all_ports = true
health_check = local.health_check
backends = [
{
group = module.sap_hana_umig_primary.self_links[0]
description = "Primary instance backend group"
failover = false
},
{
group = module.sap_hana_umig_secondary.self_links[0]
description = "Secondary instance backend group"
failover = true
},
]
}
data "google_compute_subnetwork" "subnetwork" {
name = var.subnetwork
region = local.region
project = var.subnetwork_project
}