From 80d53d56168c269920643b76c34a56cc91555473 Mon Sep 17 00:00:00 2001 From: Michael Barroco Date: Thu, 25 Jan 2024 17:57:16 +0100 Subject: [PATCH] [infrastructure] Add variable to set kubernetes cluster version and set default to 1.24 (#989) --- .../terraform-aws-kubernetes/cluster.tf | 2 +- .../terraform-aws-kubernetes/variables.tf | 16 ++++++++++++++++ .../terraform-google-kubernetes/cluster.tf | 4 +++- .../terraform-google-kubernetes/variables.tf | 16 ++++++++++++++++ .../modules/terraform-aws-dss/TFVARS.md | 10 ++++++++++ .../modules/terraform-aws-dss/main.tf | 1 + .../modules/terraform-aws-dss/variables.tf | 16 ++++++++++++++++ .../modules/terraform-google-dss/README.md | 7 ++++--- .../modules/terraform-google-dss/TFVARS.md | 10 ++++++++++ .../modules/terraform-google-dss/main.tf | 1 + .../modules/terraform-google-dss/variables.tf | 16 ++++++++++++++++ deploy/infrastructure/utils/README.md | 8 +++++--- .../utils/definitions/kubernetes_version.tf | 14 ++++++++++++++ deploy/infrastructure/utils/variables.py | 3 ++- deploy/operations/ci/aws-1/main.tf | 1 + deploy/operations/ci/aws-1/terraform.tfvars | 1 + deploy/operations/ci/aws-1/variables.tf | 16 ++++++++++++++++ 17 files changed, 133 insertions(+), 9 deletions(-) create mode 100644 deploy/infrastructure/utils/definitions/kubernetes_version.tf diff --git a/deploy/infrastructure/dependencies/terraform-aws-kubernetes/cluster.tf b/deploy/infrastructure/dependencies/terraform-aws-kubernetes/cluster.tf index 6a8d52077..0f9206bd5 100644 --- a/deploy/infrastructure/dependencies/terraform-aws-kubernetes/cluster.tf +++ b/deploy/infrastructure/dependencies/terraform-aws-kubernetes/cluster.tf @@ -23,7 +23,7 @@ resource "aws_eks_cluster" "kubernetes_cluster" { aws_eip.ip_crdb ] - version = "1.24" + version = var.kubernetes_version } resource "aws_eks_node_group" "eks_node_group" { diff --git a/deploy/infrastructure/dependencies/terraform-aws-kubernetes/variables.tf b/deploy/infrastructure/dependencies/terraform-aws-kubernetes/variables.tf index 1b73a3e34..2e9f848bd 100644 --- a/deploy/infrastructure/dependencies/terraform-aws-kubernetes/variables.tf +++ b/deploy/infrastructure/dependencies/terraform-aws-kubernetes/variables.tf @@ -87,3 +87,19 @@ variable "node_count" { } } +variable "kubernetes_version" { + type = string + description = <<-EOT + Desired version of the Kubernetes cluster control plane and nodes. + + Supported versions: + - 1.24 + EOT + + validation { + condition = var.kubernetes_version == "1.24" + error_message = "Only 1.24 is supported." + } +} + + diff --git a/deploy/infrastructure/dependencies/terraform-google-kubernetes/cluster.tf b/deploy/infrastructure/dependencies/terraform-google-kubernetes/cluster.tf index 139433427..88939d97e 100644 --- a/deploy/infrastructure/dependencies/terraform-google-kubernetes/cluster.tf +++ b/deploy/infrastructure/dependencies/terraform-google-kubernetes/cluster.tf @@ -11,6 +11,8 @@ resource "google_container_cluster" "kubernetes_cluster" { ip_allocation_policy { # Intentionally left empty. } + + min_master_version = var.kubernetes_version } resource "google_container_node_pool" "dss_pool" { @@ -55,4 +57,4 @@ resource "google_compute_address" "ip_crdb" { locals { kubectl_cluster_context_name = format("gke_%s_%s_%s", google_container_cluster.kubernetes_cluster.project, google_container_cluster.kubernetes_cluster.location, google_container_cluster.kubernetes_cluster.name) -} \ No newline at end of file +} diff --git a/deploy/infrastructure/dependencies/terraform-google-kubernetes/variables.tf b/deploy/infrastructure/dependencies/terraform-google-kubernetes/variables.tf index dbaae9ed1..709547d85 100644 --- a/deploy/infrastructure/dependencies/terraform-google-kubernetes/variables.tf +++ b/deploy/infrastructure/dependencies/terraform-google-kubernetes/variables.tf @@ -78,3 +78,19 @@ variable "node_count" { } } +variable "kubernetes_version" { + type = string + description = <<-EOT + Desired version of the Kubernetes cluster control plane and nodes. + + Supported versions: + - 1.24 + EOT + + validation { + condition = var.kubernetes_version == "1.24" + error_message = "Only 1.24 is supported." + } +} + + diff --git a/deploy/infrastructure/modules/terraform-aws-dss/TFVARS.md b/deploy/infrastructure/modules/terraform-aws-dss/TFVARS.md index 99b04c8ed..236be8056 100644 --- a/deploy/infrastructure/modules/terraform-aws-dss/TFVARS.md +++ b/deploy/infrastructure/modules/terraform-aws-dss/TFVARS.md @@ -88,6 +88,16 @@ Number of Kubernetes nodes which should correspond to the desired CockroachDB no Example: `3` +### kubernetes_version + +*Type: `string`* + +Desired version of the Kubernetes cluster control plane and nodes. + +Supported versions: +- 1.24 + + ### aws_kubernetes_storage_class *Type: `string`* diff --git a/deploy/infrastructure/modules/terraform-aws-dss/main.tf b/deploy/infrastructure/modules/terraform-aws-dss/main.tf index fdf906cf8..7073c7ca4 100644 --- a/deploy/infrastructure/modules/terraform-aws-dss/main.tf +++ b/deploy/infrastructure/modules/terraform-aws-dss/main.tf @@ -8,6 +8,7 @@ module "terraform-aws-kubernetes" { aws_route53_zone_id = var.aws_route53_zone_id aws_iam_permissions_boundary = var.aws_iam_permissions_boundary node_count = var.node_count + kubernetes_version = var.kubernetes_version source = "../../dependencies/terraform-aws-kubernetes" } diff --git a/deploy/infrastructure/modules/terraform-aws-dss/variables.tf b/deploy/infrastructure/modules/terraform-aws-dss/variables.tf index a4a71745d..486ca2f66 100644 --- a/deploy/infrastructure/modules/terraform-aws-dss/variables.tf +++ b/deploy/infrastructure/modules/terraform-aws-dss/variables.tf @@ -87,6 +87,22 @@ variable "node_count" { } } +variable "kubernetes_version" { + type = string + description = <<-EOT + Desired version of the Kubernetes cluster control plane and nodes. + + Supported versions: + - 1.24 + EOT + + validation { + condition = var.kubernetes_version == "1.24" + error_message = "Only 1.24 is supported." + } +} + + variable "aws_kubernetes_storage_class" { type = string description = <<-EOT diff --git a/deploy/infrastructure/modules/terraform-google-dss/README.md b/deploy/infrastructure/modules/terraform-google-dss/README.md index cabeba6a0..ab1ea2f4b 100644 --- a/deploy/infrastructure/modules/terraform-google-dss/README.md +++ b/deploy/infrastructure/modules/terraform-google-dss/README.md @@ -20,8 +20,9 @@ Download & install the following tools to your workstation: 2. Check that the DSS project is correctly selected: gcloud config list project 1. Set another one if needed using: `gcloud config set project $GOOGLE_PROJECT_NAME` 3. Enable the following API using [Google Cloud CLI](https://cloud.google.com/endpoints/docs/openapi/enable-api#gcloud): - 1. `container.googleapis.com` - 2. If you want to manage DNS entries with terraform: `dns.googleapis.com` + 1. `compute.googleapis.com` + 2. `container.googleapis.com` + 3. If you want to manage DNS entries with terraform: `dns.googleapis.com` 4. Install the auth plugin to connect to kubernetes: `gcloud components install gke-gcloud-auth-plugin` 5. Run `gcloud auth application-default login` to generate credentials to call Google Cloud Platform APIs. 1. If the result of performing the authorization indicates 404 in the browser, check whether a local dummy-oauth instance is running (using port 8085). Stop the dummy-oauth instance if it is running. @@ -70,4 +71,4 @@ It contains scripts to operate the cluster and setup the services. To delete all resources, run `terraform destroy`. Note that this operation can't be reverted and all data will be lost. -For Google Cloud Engine, make sure to manually clean up the persistent storage: https://console.cloud.google.com/compute/disks \ No newline at end of file +For Google Cloud Engine, make sure to manually clean up the persistent storage: https://console.cloud.google.com/compute/disks diff --git a/deploy/infrastructure/modules/terraform-google-dss/TFVARS.md b/deploy/infrastructure/modules/terraform-google-dss/TFVARS.md index ca103ed58..df1f8f068 100644 --- a/deploy/infrastructure/modules/terraform-google-dss/TFVARS.md +++ b/deploy/infrastructure/modules/terraform-google-dss/TFVARS.md @@ -82,6 +82,16 @@ Number of Kubernetes nodes which should correspond to the desired CockroachDB no Example: `3` +### kubernetes_version + +*Type: `string`* + +Desired version of the Kubernetes cluster control plane and nodes. + +Supported versions: +- 1.24 + + ### google_kubernetes_storage_class *Type: `string`* diff --git a/deploy/infrastructure/modules/terraform-google-dss/main.tf b/deploy/infrastructure/modules/terraform-google-dss/main.tf index 70edfea4a..b21b7c4b8 100644 --- a/deploy/infrastructure/modules/terraform-google-dss/main.tf +++ b/deploy/infrastructure/modules/terraform-google-dss/main.tf @@ -8,6 +8,7 @@ module "terraform-google-kubernetes" { google_dns_managed_zone_name = var.google_dns_managed_zone_name google_machine_type = var.google_machine_type node_count = var.node_count + kubernetes_version = var.kubernetes_version source = "../../dependencies/terraform-google-kubernetes" } diff --git a/deploy/infrastructure/modules/terraform-google-dss/variables.tf b/deploy/infrastructure/modules/terraform-google-dss/variables.tf index a131be3c0..64d7bfb68 100644 --- a/deploy/infrastructure/modules/terraform-google-dss/variables.tf +++ b/deploy/infrastructure/modules/terraform-google-dss/variables.tf @@ -78,6 +78,22 @@ variable "node_count" { } } +variable "kubernetes_version" { + type = string + description = <<-EOT + Desired version of the Kubernetes cluster control plane and nodes. + + Supported versions: + - 1.24 + EOT + + validation { + condition = var.kubernetes_version == "1.24" + error_message = "Only 1.24 is supported." + } +} + + variable "google_kubernetes_storage_class" { type = string description = <<-EOT diff --git a/deploy/infrastructure/utils/README.md b/deploy/infrastructure/utils/README.md index e9c336372..013fe8afd 100644 --- a/deploy/infrastructure/utils/README.md +++ b/deploy/infrastructure/utils/README.md @@ -2,6 +2,8 @@ This directory contains the following tools to simplify the management of the terraform modules: -1. `generate_terraform_variables.sh`: Terraform variables can't be shared between modules without repeating their definition at every level of encapsulation. - To prevent repeating ourselves and to maintain a consistent level of quality for every module and dependencies, this script takes variables - in the `definitions` directory and creates a `variables.tf` file in each modules with the appropriate content. +## `generate_terraform_variables.sh` +Terraform variables can't be shared between modules without repeating their definition at every level of encapsulation. +To prevent repeating ourselves and to maintain a consistent level of quality for every module and dependencies, this script takes variables +in the `definitions` directory and creates a `variables.tf` file in each modules with the appropriate content. +Assignment of `definitions` files to modules is made in `variables.py`. diff --git a/deploy/infrastructure/utils/definitions/kubernetes_version.tf b/deploy/infrastructure/utils/definitions/kubernetes_version.tf new file mode 100644 index 000000000..cabeeb36c --- /dev/null +++ b/deploy/infrastructure/utils/definitions/kubernetes_version.tf @@ -0,0 +1,14 @@ +variable "kubernetes_version" { + type = string + description = <<-EOT + Desired version of the Kubernetes cluster control plane and nodes. + + Supported versions: + - 1.24 + EOT + + validation { + condition = var.kubernetes_version == "1.24" + error_message = "Only 1.24 is supported." + } +} diff --git a/deploy/infrastructure/utils/variables.py b/deploy/infrastructure/utils/variables.py index 633686634..45db6bad6 100755 --- a/deploy/infrastructure/utils/variables.py +++ b/deploy/infrastructure/utils/variables.py @@ -36,13 +36,14 @@ "desired_scd_db_version", "crdb_locality", "crdb_external_nodes", - "kubernetes_namespace", + "kubernetes_namespace" ] # dependencies/terraform-*-kubernetes COMMON_KUBERNETES_VARIABLES = GLOBAL_VARIABLES + [ "cluster_name", "node_count", + "kubernetes_version" ] # dependencies/terraform-google-kubernetes diff --git a/deploy/operations/ci/aws-1/main.tf b/deploy/operations/ci/aws-1/main.tf index 3b0fee971..46aadff74 100644 --- a/deploy/operations/ci/aws-1/main.tf +++ b/deploy/operations/ci/aws-1/main.tf @@ -20,6 +20,7 @@ module "terraform-aws-dss" { crdb_hostname_suffix = var.crdb_hostname_suffix crdb_locality = var.crdb_locality image = var.image + kubernetes_version = var.kubernetes_version node_count = 3 should_init = true enable_scd = true diff --git a/deploy/operations/ci/aws-1/terraform.tfvars b/deploy/operations/ci/aws-1/terraform.tfvars index cbccb61d3..b547990b6 100644 --- a/deploy/operations/ci/aws-1/terraform.tfvars +++ b/deploy/operations/ci/aws-1/terraform.tfvars @@ -11,6 +11,7 @@ app_hostname = "dss.ci.aws-interuss.uspace.dev" crdb_hostname_suffix = "db.ci.aws-interuss.uspace.dev" # Kubernetes configuration +kubernetes_version = 1.24 cluster_name = "dss-ci-aws-ue1" node_count = 3 aws_instance_type = "t3.medium" diff --git a/deploy/operations/ci/aws-1/variables.tf b/deploy/operations/ci/aws-1/variables.tf index a4a71745d..486ca2f66 100644 --- a/deploy/operations/ci/aws-1/variables.tf +++ b/deploy/operations/ci/aws-1/variables.tf @@ -87,6 +87,22 @@ variable "node_count" { } } +variable "kubernetes_version" { + type = string + description = <<-EOT + Desired version of the Kubernetes cluster control plane and nodes. + + Supported versions: + - 1.24 + EOT + + validation { + condition = var.kubernetes_version == "1.24" + error_message = "Only 1.24 is supported." + } +} + + variable "aws_kubernetes_storage_class" { type = string description = <<-EOT