Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
Added cluster auto scaling
Updated docs
Added tests for cluster auto scaling in node_pool fixture
  • Loading branch information
kopachevsky committed Nov 19, 2019
1 parent 3945205 commit 275e427
Show file tree
Hide file tree
Showing 25 changed files with 214 additions and 6 deletions.
24 changes: 24 additions & 0 deletions autogen/cluster.tf
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ resource "google_container_cluster" "primary" {
}
}


{% if beta_cluster %}
dynamic "release_channel" {
for_each = local.release_channel
Expand All @@ -62,6 +63,29 @@ resource "google_container_cluster" "primary" {
monitoring_service = var.monitoring_service

{% if beta_cluster %}
cluster_autoscaling {
enabled = var.cluster_autoscaling.enabled
dynamic "resource_limits" {
for_each = concat(
var.cluster_autoscaling.enabled && lookup(var.cluster_autoscaling.resource_limits, "min_cpu_cores", 0) > 0 && lookup(var.cluster_autoscaling.resource_limits, "max_cpu_cores", 0) > 0 ? [{
resource_type = "cpu"
minimum = var.cluster_autoscaling.resource_limits["min_cpu_cores"]
maximum = var.cluster_autoscaling.resource_limits["max_cpu_cores"]
}] : [],
var.cluster_autoscaling.enabled && lookup(var.cluster_autoscaling.resource_limits, "min_memory_gb", 0) > 0 && lookup(var.cluster_autoscaling.resource_limits, "max_memory_gb", 0) > 0 ? [{
resource_type = "memory"
minimum = var.cluster_autoscaling.resource_limits["min_memory_gb"]
maximum = var.cluster_autoscaling.resource_limits["max_memory_gb"]
}] : []
)
content {
resource_type = lookup(resource_limits.value, "resource_type")
minimum = lookup(resource_limits.value, "minimum")
maximum = lookup(resource_limits.value, "maximum")
}
}
}

enable_binary_authorization = var.enable_binary_authorization
enable_intranode_visibility = var.enable_intranode_visibility
default_max_pods_per_node = var.default_max_pods_per_node
Expand Down
14 changes: 13 additions & 1 deletion autogen/variables.tf
Original file line number Diff line number Diff line change
Expand Up @@ -178,8 +178,20 @@ variable "node_pools_metadata" {
default-node-pool = {}
}
}

{% if beta_cluster %}

variable "cluster_autoscaling" {
type = object({
enabled = bool
resource_limits = map(number)
})
default = {
enabled = false
resource_limits = {}
}
description = "Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling)"
}

variable "node_pools_taints" {
type = map(list(object({key=string,value=string,effect=string})))
description = "Map of lists containing node taints by node-pool name"
Expand Down
1 change: 1 addition & 0 deletions cluster.tf
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ resource "google_container_cluster" "primary" {
}



subnetwork = data.google_compute_subnetwork.gke_subnetwork.self_link
min_master_version = local.master_version

Expand Down
1 change: 1 addition & 0 deletions examples/node_pool/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ This example illustrates how to create a cluster with multiple custom node-pool

| Name | Description | Type | Default | Required |
|------|-------------|:----:|:-----:|:-----:|
| cluster\_autoscaling | Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling) | object | `<map>` | no |
| cluster\_name\_suffix | A suffix to append to the default cluster name | string | `""` | no |
| compute\_engine\_service\_account | Service account to associate to the nodes in the cluster | string | n/a | yes |
| ip\_range\_pods | The secondary ip range to use for pods | string | n/a | yes |
Expand Down
3 changes: 2 additions & 1 deletion examples/node_pool/main.tf
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ provider "google-beta" {
module "gke" {
source = "../../modules/beta-public-cluster/"
project_id = var.project_id
name = "${local.cluster_type}-cluster${var.cluster_name_suffix}"
name = join("", [local.cluster_type, "-cluster", var.cluster_name_suffix])
region = var.region
zones = var.zones
network = var.network
Expand All @@ -36,6 +36,7 @@ module "gke" {
create_service_account = false
remove_default_node_pool = true
disable_legacy_metadata_endpoints = false
cluster_autoscaling = var.cluster_autoscaling

node_pools = [
{
Expand Down
11 changes: 11 additions & 0 deletions examples/node_pool/variables.tf
Original file line number Diff line number Diff line change
Expand Up @@ -52,3 +52,14 @@ variable "compute_engine_service_account" {
description = "Service account to associate to the nodes in the cluster"
}

variable "cluster_autoscaling" {
type = object({
enabled = bool
resource_limits = map(number)
})
default = {
enabled = false
resource_limits = {}
}
description = "Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling)"
}
1 change: 1 addition & 0 deletions examples/simple_regional_beta/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ This example illustrates how to create a simple cluster with beta features.
| Name | Description | Type | Default | Required |
|------|-------------|:----:|:-----:|:-----:|
| cloudrun | Boolean to enable / disable CloudRun | string | `"true"` | no |
| cluster\_autoscaling | Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling) | object | `<map>` | no |
| cluster\_name\_suffix | A suffix to append to the default cluster name | string | `""` | no |
| compute\_engine\_service\_account | Service account to associate to the nodes in the cluster | string | n/a | yes |
| ip\_range\_pods | The secondary ip range to use for pods | string | n/a | yes |
Expand Down
3 changes: 2 additions & 1 deletion examples/simple_regional_beta/main.tf
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ provider "google-beta" {
module "gke" {
source = "../../modules/beta-public-cluster/"
project_id = var.project_id
name = "${local.cluster_type}-cluster${var.cluster_name_suffix}"
name = join("", [local.cluster_type, "-cluster", var.cluster_name_suffix])
regional = true
region = var.region
network = var.network
Expand All @@ -41,6 +41,7 @@ module "gke" {
sandbox_enabled = var.sandbox_enabled
remove_default_node_pool = var.remove_default_node_pool
node_pools = var.node_pools
cluster_autoscaling = var.cluster_autoscaling
}

data "google_client_config" "default" {
Expand Down
12 changes: 12 additions & 0 deletions examples/simple_regional_beta/variables.tf
Original file line number Diff line number Diff line change
Expand Up @@ -85,3 +85,15 @@ variable "node_pools" {
},
]
}

variable "cluster_autoscaling" {
type = object({
enabled = bool
resource_limits = map(number)
})
default = {
enabled = false
resource_limits = {}
}
description = "Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling)"
}
1 change: 1 addition & 0 deletions modules/beta-private-cluster-update-variant/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,7 @@ In either case, upgrading to module version `v1.0.0` will trigger a recreation o
| basic\_auth\_password | The password to be used with Basic Authentication. | string | `""` | no |
| basic\_auth\_username | The username to be used with Basic Authentication. An empty value will disable Basic Authentication, which is the recommended configuration. | string | `""` | no |
| cloudrun | (Beta) Enable CloudRun addon | string | `"false"` | no |
| cluster\_autoscaling | Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling) | object | `<map>` | no |
| cluster\_ipv4\_cidr | The IP address range of the kubernetes pods in this cluster. Default is an automatically assigned CIDR. | string | `""` | no |
| cluster\_resource\_labels | The GCE resource labels (a map of key/value pairs) to be applied to the cluster | map(string) | `<map>` | no |
| configure\_ip\_masq | Enables the installation of ip masquerading, which is usually no longer required when using aliasied IP addresses. IP masquerading uses a kubectl call, so when you have a private cluster, you will need access to the API server. | string | `"false"` | no |
Expand Down
24 changes: 24 additions & 0 deletions modules/beta-private-cluster-update-variant/cluster.tf
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ resource "google_container_cluster" "primary" {
}
}


dynamic "release_channel" {
for_each = local.release_channel

Expand All @@ -55,6 +56,29 @@ resource "google_container_cluster" "primary" {
logging_service = var.logging_service
monitoring_service = var.monitoring_service

cluster_autoscaling {
enabled = var.cluster_autoscaling.enabled
dynamic "resource_limits" {
for_each = concat(
var.cluster_autoscaling.enabled && lookup(var.cluster_autoscaling.resource_limits, "min_cpu_cores", 0) > 0 && lookup(var.cluster_autoscaling.resource_limits, "max_cpu_cores", 0) > 0 ? [{
resource_type = "cpu"
minimum = var.cluster_autoscaling.resource_limits["min_cpu_cores"]
maximum = var.cluster_autoscaling.resource_limits["max_cpu_cores"]
}] : [],
var.cluster_autoscaling.enabled && lookup(var.cluster_autoscaling.resource_limits, "min_memory_gb", 0) > 0 && lookup(var.cluster_autoscaling.resource_limits, "max_memory_gb", 0) > 0 ? [{
resource_type = "memory"
minimum = var.cluster_autoscaling.resource_limits["min_memory_gb"]
maximum = var.cluster_autoscaling.resource_limits["max_memory_gb"]
}] : []
)
content {
resource_type = lookup(resource_limits.value, "resource_type")
minimum = lookup(resource_limits.value, "minimum")
maximum = lookup(resource_limits.value, "maximum")
}
}
}

enable_binary_authorization = var.enable_binary_authorization
enable_intranode_visibility = var.enable_intranode_visibility
default_max_pods_per_node = var.default_max_pods_per_node
Expand Down
12 changes: 12 additions & 0 deletions modules/beta-private-cluster-update-variant/variables.tf
Original file line number Diff line number Diff line change
Expand Up @@ -179,6 +179,18 @@ variable "node_pools_metadata" {
}
}

variable "cluster_autoscaling" {
type = object({
enabled = bool
resource_limits = map(number)
})
default = {
enabled = false
resource_limits = {}
}
description = "Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling)"
}

variable "node_pools_taints" {
type = map(list(object({ key = string, value = string, effect = string })))
description = "Map of lists containing node taints by node-pool name"
Expand Down
1 change: 1 addition & 0 deletions modules/beta-private-cluster/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,7 @@ In either case, upgrading to module version `v1.0.0` will trigger a recreation o
| basic\_auth\_password | The password to be used with Basic Authentication. | string | `""` | no |
| basic\_auth\_username | The username to be used with Basic Authentication. An empty value will disable Basic Authentication, which is the recommended configuration. | string | `""` | no |
| cloudrun | (Beta) Enable CloudRun addon | string | `"false"` | no |
| cluster\_autoscaling | Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling) | object | `<map>` | no |
| cluster\_ipv4\_cidr | The IP address range of the kubernetes pods in this cluster. Default is an automatically assigned CIDR. | string | `""` | no |
| cluster\_resource\_labels | The GCE resource labels (a map of key/value pairs) to be applied to the cluster | map(string) | `<map>` | no |
| configure\_ip\_masq | Enables the installation of ip masquerading, which is usually no longer required when using aliasied IP addresses. IP masquerading uses a kubectl call, so when you have a private cluster, you will need access to the API server. | string | `"false"` | no |
Expand Down
24 changes: 24 additions & 0 deletions modules/beta-private-cluster/cluster.tf
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ resource "google_container_cluster" "primary" {
}
}


dynamic "release_channel" {
for_each = local.release_channel

Expand All @@ -55,6 +56,29 @@ resource "google_container_cluster" "primary" {
logging_service = var.logging_service
monitoring_service = var.monitoring_service

cluster_autoscaling {
enabled = var.cluster_autoscaling.enabled
dynamic "resource_limits" {
for_each = concat(
var.cluster_autoscaling.enabled && lookup(var.cluster_autoscaling.resource_limits, "min_cpu_cores", 0) > 0 && lookup(var.cluster_autoscaling.resource_limits, "max_cpu_cores", 0) > 0 ? [{
resource_type = "cpu"
minimum = var.cluster_autoscaling.resource_limits["min_cpu_cores"]
maximum = var.cluster_autoscaling.resource_limits["max_cpu_cores"]
}] : [],
var.cluster_autoscaling.enabled && lookup(var.cluster_autoscaling.resource_limits, "min_memory_gb", 0) > 0 && lookup(var.cluster_autoscaling.resource_limits, "max_memory_gb", 0) > 0 ? [{
resource_type = "memory"
minimum = var.cluster_autoscaling.resource_limits["min_memory_gb"]
maximum = var.cluster_autoscaling.resource_limits["max_memory_gb"]
}] : []
)
content {
resource_type = lookup(resource_limits.value, "resource_type")
minimum = lookup(resource_limits.value, "minimum")
maximum = lookup(resource_limits.value, "maximum")
}
}
}

enable_binary_authorization = var.enable_binary_authorization
enable_intranode_visibility = var.enable_intranode_visibility
default_max_pods_per_node = var.default_max_pods_per_node
Expand Down
12 changes: 12 additions & 0 deletions modules/beta-private-cluster/variables.tf
Original file line number Diff line number Diff line change
Expand Up @@ -179,6 +179,18 @@ variable "node_pools_metadata" {
}
}

variable "cluster_autoscaling" {
type = object({
enabled = bool
resource_limits = map(number)
})
default = {
enabled = false
resource_limits = {}
}
description = "Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling)"
}

variable "node_pools_taints" {
type = map(list(object({ key = string, value = string, effect = string })))
description = "Map of lists containing node taints by node-pool name"
Expand Down
1 change: 1 addition & 0 deletions modules/beta-public-cluster/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,7 @@ In either case, upgrading to module version `v1.0.0` will trigger a recreation o
| basic\_auth\_password | The password to be used with Basic Authentication. | string | `""` | no |
| basic\_auth\_username | The username to be used with Basic Authentication. An empty value will disable Basic Authentication, which is the recommended configuration. | string | `""` | no |
| cloudrun | (Beta) Enable CloudRun addon | string | `"false"` | no |
| cluster\_autoscaling | Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling) | object | `<map>` | no |
| cluster\_ipv4\_cidr | The IP address range of the kubernetes pods in this cluster. Default is an automatically assigned CIDR. | string | `""` | no |
| cluster\_resource\_labels | The GCE resource labels (a map of key/value pairs) to be applied to the cluster | map(string) | `<map>` | no |
| configure\_ip\_masq | Enables the installation of ip masquerading, which is usually no longer required when using aliasied IP addresses. IP masquerading uses a kubectl call, so when you have a private cluster, you will need access to the API server. | string | `"false"` | no |
Expand Down
24 changes: 24 additions & 0 deletions modules/beta-public-cluster/cluster.tf
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ resource "google_container_cluster" "primary" {
}
}


dynamic "release_channel" {
for_each = local.release_channel

Expand All @@ -55,6 +56,29 @@ resource "google_container_cluster" "primary" {
logging_service = var.logging_service
monitoring_service = var.monitoring_service

cluster_autoscaling {
enabled = var.cluster_autoscaling.enabled
dynamic "resource_limits" {
for_each = concat(
var.cluster_autoscaling.enabled && lookup(var.cluster_autoscaling.resource_limits, "min_cpu_cores", 0) > 0 && lookup(var.cluster_autoscaling.resource_limits, "max_cpu_cores", 0) > 0 ? [{
resource_type = "cpu"
minimum = var.cluster_autoscaling.resource_limits["min_cpu_cores"]
maximum = var.cluster_autoscaling.resource_limits["max_cpu_cores"]
}] : [],
var.cluster_autoscaling.enabled && lookup(var.cluster_autoscaling.resource_limits, "min_memory_gb", 0) > 0 && lookup(var.cluster_autoscaling.resource_limits, "max_memory_gb", 0) > 0 ? [{
resource_type = "memory"
minimum = var.cluster_autoscaling.resource_limits["min_memory_gb"]
maximum = var.cluster_autoscaling.resource_limits["max_memory_gb"]
}] : []
)
content {
resource_type = lookup(resource_limits.value, "resource_type")
minimum = lookup(resource_limits.value, "minimum")
maximum = lookup(resource_limits.value, "maximum")
}
}
}

enable_binary_authorization = var.enable_binary_authorization
enable_intranode_visibility = var.enable_intranode_visibility
default_max_pods_per_node = var.default_max_pods_per_node
Expand Down
12 changes: 12 additions & 0 deletions modules/beta-public-cluster/variables.tf
Original file line number Diff line number Diff line change
Expand Up @@ -179,6 +179,18 @@ variable "node_pools_metadata" {
}
}

variable "cluster_autoscaling" {
type = object({
enabled = bool
resource_limits = map(number)
})
default = {
enabled = false
resource_limits = {}
}
description = "Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling)"
}

variable "node_pools_taints" {
type = map(list(object({ key = string, value = string, effect = string })))
description = "Map of lists containing node taints by node-pool name"
Expand Down
1 change: 1 addition & 0 deletions modules/private-cluster-update-variant/cluster.tf
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ resource "google_container_cluster" "primary" {
}



subnetwork = data.google_compute_subnetwork.gke_subnetwork.self_link
min_master_version = local.master_version

Expand Down
1 change: 0 additions & 1 deletion modules/private-cluster-update-variant/variables.tf
Original file line number Diff line number Diff line change
Expand Up @@ -178,7 +178,6 @@ variable "node_pools_metadata" {
default-node-pool = {}
}
}

variable "node_pools_tags" {
type = map(list(string))
description = "Map of lists containing node network tags by node-pool name"
Expand Down
1 change: 1 addition & 0 deletions modules/private-cluster/cluster.tf
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ resource "google_container_cluster" "primary" {
}



subnetwork = data.google_compute_subnetwork.gke_subnetwork.self_link
min_master_version = local.master_version

Expand Down
1 change: 0 additions & 1 deletion modules/private-cluster/variables.tf
Original file line number Diff line number Diff line change
Expand Up @@ -178,7 +178,6 @@ variable "node_pools_metadata" {
default-node-pool = {}
}
}

variable "node_pools_tags" {
type = map(list(string))
description = "Map of lists containing node network tags by node-pool name"
Expand Down
10 changes: 10 additions & 0 deletions test/fixtures/node_pool/example.tf
Original file line number Diff line number Diff line change
Expand Up @@ -26,5 +26,15 @@ module "example" {
ip_range_pods = google_compute_subnetwork.main.secondary_ip_range[0].range_name
ip_range_services = google_compute_subnetwork.main.secondary_ip_range[1].range_name
compute_engine_service_account = var.compute_engine_service_account

cluster_autoscaling = {
enabled = true
resource_limits = {
max_cpu_cores = 20
min_cpu_cores = 5
max_memory_gb = 30
min_memory_gb = 10
}
}
}

Loading

0 comments on commit 275e427

Please sign in to comment.