...

/

Creating Worker Nodes

Creating Worker Nodes

Learn how to create worker nodes and view them using Terraform.

We'll cover the following...

Defining worker nodes

We can manage worker nodes through the aws_eks_node_group module. We use the following definition for this purpose.

Press + to interact
resource "aws_eks_node_group" "primary" {
cluster_name = aws_eks_cluster.primary.name
version = var.k8s_version
release_version = var.release_version
node_group_name = "devops-catalog"
node_role_arn = aws_iam_role.worker.arn
subnet_ids = aws_subnet.worker[*].id
instance_types = [var.machine_type]
scaling_config {
desired_size = var.min_node_count
max_size = var.max_node_count
min_size = var.min_node_count
}
depends_on = [
aws_iam_role_policy_attachment.worker,
aws_iam_role_policy_attachment.cni,
aws_iam_role_policy_attachment.registry,
]
timeouts {
create = "15m"
update = "1h"
}
}
resource "aws_iam_role" "worker" {
name = "devops-catalog-worker"
assume_role_policy = jsonencode({
Statement = [{
Action = "sts:AssumeRole"
Effect = "Allow"
Principal = {
Service = "ec2.amazonaws.com"
}
}]
Version = "2012-10-17"
})
}
resource "aws_iam_role_policy_attachment" "worker" {
policy_arn = "arn:aws:iam::aws:policy/AmazonEKSWorkerNodePolicy"
role = aws_iam_role.worker.name
}
resource "aws_iam_role_policy_attachment" "cni" {
policy_arn = "arn:aws:iam::aws:policy/AmazonEKS_CNI_Policy"
role = aws_iam_role.worker.name
}
resource "aws_iam_role_policy_attachment" "registry" {
policy_arn = "arn:aws:iam::aws:policy/AmazonEC2ContainerRegistryReadOnly"
role = aws_iam_role.worker.name
}
resource "aws_internet_gateway" "worker" {
vpc_id = aws_vpc.worker.id
tags = {
Name = "devops-catalog"
}
}
resource "aws_route_table" "worker" {
vpc_id = aws_vpc.worker.id
route {
cidr_block = "0.0.0.0/0"
gateway_id = aws_internet_gateway.worker.id
}
}
resource "aws_route_table_association" "worker" {
count = 3
subnet_id = aws_subnet.worker[count.index].id
route_table_id = aws_route_table.worker.id
}

Like with the control plane, we have to define a few additional resources besides the aws_eks_node_group. Just like before, we won’t go into details, but only do a brief overview. We can see that the node group definition follows a similar pattern to the one we used for the control plane.

  • Line 2: We have the cluster name (cluster_name) that references the name field of the aws_eks_cluster.primary resource.
  • Lines 3–4: The version is the value of the k8s_version variable, and the AMI release version is provided through
...