Difference between revisions of "Terraform resource: google container node pool"

From wikieduonline
Jump to navigation Jump to search
 
(3 intermediate revisions by the same user not shown)
Line 1: Line 1:
 
https://registry.terraform.io/providers/hashicorp/google/latest/docs/resources/container_node_pool
 
https://registry.terraform.io/providers/hashicorp/google/latest/docs/resources/container_node_pool
 
  google_container_node_pool
 
  google_container_node_pool
 +
 +
== Official example ==
 +
 +
resource "google_service_account" "default" {
 +
  account_id  = "service-account-id"
 +
  display_name = "Service Account"
 +
}
 +
 +
resource "google_container_cluster" "primary" {
 +
  name    = "my-gke-cluster"
 +
  [[location]] = "us-central1" 
 +
 +
  # We can't create a cluster with no node pool defined, but we want to only use
 +
  # separately managed node pools. So we create the smallest possible default
 +
  # node pool and immediately delete it.
 +
  remove_default_node_pool = true
 +
  initial_node_count      = 1
 +
}
 +
 +
resource "google_container_node_pool" "primary_preemptible_nodes" {
 +
  name      = "my-node-pool"
 +
  cluster    = google_container_cluster.primary.id
 +
  node_count = 1
 +
 +
  node_config {
 +
    preemptible  = true
 +
    [[machine_type]] = "[[e2-medium]]"
 +
 +
    # Google recommends custom service accounts that have cloud-platform scope and
 +
permissions granted via IAM Roles.
 +
    service_account = google_service_account.default.email
 +
    oauth_scopes = [
 +
      "https://www.googleapis.com/auth/cloud-platform"
 +
    ]
 +
  }
 +
}
  
 
== Related ==
 
== Related ==
Line 8: Line 44:
 
== See also ==
 
== See also ==
 
* {{tf gcp}}
 
* {{tf gcp}}
* {{GKE}}
+
* {{tf GKE}}
  
 
[[Category:GKE]]
 
[[Category:GKE]]
 
[[Category:Terraform]]
 
[[Category:Terraform]]

Latest revision as of 17:55, 7 December 2023

https://registry.terraform.io/providers/hashicorp/google/latest/docs/resources/container_node_pool

google_container_node_pool

Official example[edit]

resource "google_service_account" "default" {
  account_id   = "service-account-id"
  display_name = "Service Account"
}

resource "google_container_cluster" "primary" {
  name     = "my-gke-cluster"
  location = "us-central1"  

  # We can't create a cluster with no node pool defined, but we want to only use
  # separately managed node pools. So we create the smallest possible default
  # node pool and immediately delete it.
  remove_default_node_pool = true
  initial_node_count       = 1
}

resource "google_container_node_pool" "primary_preemptible_nodes" {
  name       = "my-node-pool"
  cluster    = google_container_cluster.primary.id
  node_count = 1

  node_config {
    preemptible  = true
    machine_type = "e2-medium" 

    # Google recommends custom service accounts that have cloud-platform scope and 
permissions granted via IAM Roles.
    service_account = google_service_account.default.email
    oauth_scopes = [
      "https://www.googleapis.com/auth/cloud-platform"
    ]
  }
}

Related[edit]

See also[edit]

Advertising: