Amazon Web Services (AWS) Elastic Kubernetes Service (EKS) - Provision an Elastic Kubernetes Service (EKS) Cluster using Terraform
by
Jeremy Canfield |
Updated: October 23 2023
| Amazon Web Services (AWS) Elastic Kubernetes Service (EKS) articles
This assumes you have setup Terraform as described in Amazon Web Services (AWS) - Getting Started with Terraform.
Let's say you have the following files on your Terraform server.
├── required_providers.tf
├── elastic_kubernetes_service (directory)
│ ├── eks.tf
│ ├── provider.tf
│ ├── security_groups.tf
required_providers.tf will almost always have this.
terraform {
required_providers {
aws = {
source = "hashicorp/aws"
}
}
}
Let's say provider.tf has the following. In this example, the "default" profile in /home/username/.aws/config and /home/username/.aws/credentials is being used. This assumes you have setup Terraform as described in Amazon Web Services (AWS) - Getting Started with Terraform.
provider "aws" {
alias = "default"
profile = "default"
region = "default"
}
And eks.tf could have the following.
resource "aws_eks_cluster" "eks_cluster" {
name = "my-eks-cluster"
role_arn = aws_iam_role.eks_cluster.arn
version = "1.28"
enabled_cluster_log_types = [
"api",
"audit",
"authenticator"
]
vpc_config {
subnet_ids = var.subnet_ids
endpoint_private_access = true
endpoint_public_access = false
security_group_ids = [aws_security_group.security_group.id]
}
depends_on = [
aws_iam_role_policy_attachment.AmazonEKSClusterPolicy,
aws_iam_role_policy_attachment.AmazonEKSVPCResourceController,
aws_cloudwatch_log_group.eks_cluster_log_group
]
tags = {
Environment = "staging"
}
}
The terraform plan command can be used to see what Terraform will try to do.
terraform plan
The terraform apply command can be used to create or update EKS Cluster.
terraform apply -auto-approve
Did you find this article helpful?
If so, consider buying me a coffee over at