# How to use repo 1. Create `terraform.tfvars` file with a few variables ```shell project = "gcp-project" region = "europe-west1" environment_name = "demo" ``` 2. Create cluster All commands will be applied via Terraform 1.7.0 and via OpenTofu, the same version. Here are OpenTofu commands. ```shell tofu init tofu apply ``` 3. Get the credentials for the new cluster (configure kubeconfig) You can see all useful commands and links in the output: ```shell tofu output ``` There is a manual command: ```shell gcloud container clusters get-credentials $(tofu output -raw kubernetes_cluster_name) --region $(tofu output -raw zone) --project $(tofu output -raw project) ``` Or just use `./get-credentials.sh` 4. Destroy all resources ```shell tofu destroy ``` ## Requirements | Name | Version | |------|---------| | [terraform](#requirement\_terraform) | ~>1.7.0 | | [google](#requirement\_google) | ~>5.27.0 | | [kubernetes](#requirement\_kubernetes) | ~>2.29.0 | ## Providers | Name | Version | |------|---------| | [google](#provider\_google) | 5.27.0 | | [kubernetes](#provider\_kubernetes) | 2.29.0 | ## Modules No modules. ## Resources | Name | Type | |------|------| | [google_compute_network.vpc](https://registry.terraform.io/providers/hashicorp/google/latest/docs/resources/compute_network) | resource | | [google_compute_subnetwork.subnet](https://registry.terraform.io/providers/hashicorp/google/latest/docs/resources/compute_subnetwork) | resource | | [google_container_cluster.primary](https://registry.terraform.io/providers/hashicorp/google/latest/docs/resources/container_cluster) | resource | | [google_container_node_pool.primary_nodes](https://registry.terraform.io/providers/hashicorp/google/latest/docs/resources/container_node_pool) | resource | | [google_project_service.service_networking](https://registry.terraform.io/providers/hashicorp/google/latest/docs/resources/project_service) | resource | | [kubernetes_namespace.demo-cluster](https://registry.terraform.io/providers/hashicorp/kubernetes/latest/docs/resources/namespace) | resource | | [google_client_config.primary](https://registry.terraform.io/providers/hashicorp/google/latest/docs/data-sources/client_config) | data source | ## Inputs | Name | Description | Type | Default | Required | |------|-------------|------|---------|:--------:| | [environment\_name](#input\_environment\_name) | n/a | `string` | `"demo"` | no | | [project](#input\_project) | Google Project to create resources in | `string` | `"demo"` | no | | [region](#input\_region) | The region to host the cluster in | `string` | `"us-central1"` | no | | [vpc\_host\_project](#input\_vpc\_host\_project) | Host Project where virtual network exists | `string` | `"demo"` | no | | [zone](#input\_zone) | The region to host the cluster in | `string` | `"us-central1-b"` | no | ## Outputs | Name | Description | |------|-------------| | [gcloud\_gke\_get\_creds](#output\_gcloud\_gke\_get\_creds) | Command to get GKE credentials | | [gcloud\_gke\_link](#output\_gcloud\_gke\_link) | GKE web ui link | | [gcloud\_vpc\_link](#output\_gcloud\_vpc\_link) | VPC web ui link | | [kubernetes\_cluster\_host](#output\_kubernetes\_cluster\_host) | GKE Cluster Host | | [kubernetes\_cluster\_name](#output\_kubernetes\_cluster\_name) | GKE Cluster Name | | [project](#output\_project) | GCloud Project ID | | [region](#output\_region) | GCloud Region | | [zone](#output\_zone) | GCloud Project ID |