This example deploys an EKS Kubernetes cluster inside a AWS VPC with proper NodeGroup and Networking Configured
To deploy your infrastructure, follow the below steps.
- Install Pulumi
- Configure Pulumi for AWS
- Configure Pulumi for Python
- Optional for K8 Auth Install
iam-authenticator
-
Install dependencies (a
virtualenv
is recommended - see Pulumi Python docs):$ virtualenv -p python3 venv $ source venv/bin/activate $ pip3 install -r requirements.txt
-
Create a new stack:
$ pulumi stack init python-eks-testing
-
Set the AWS region:
$ pulumi config set aws:region us-east-2
-
Run
pulumi up
to preview and deploy changes:$ pulumi up Previewing stack 'python-eks-testing' Previewing changes: ... Do you want to perform this update? yes Updating (python-eks-testing): Type Name Status + pulumi:pulumi:Stack aws-py-eks-python-eks-testing created + ├─ aws:iam:Role ec2-nodegroup-iam-role created + ├─ aws:iam:Role eks-iam-role created + ├─ aws:ec2:Vpc eks-vpc created + ├─ aws:iam:RolePolicyAttachment eks-workernode-policy-attachment created + ├─ aws:iam:RolePolicyAttachment eks-cni-policy-attachment created + ├─ aws:iam:RolePolicyAttachment ec2-container-ro-policy-attachment created + ├─ aws:iam:RolePolicyAttachment eks-service-policy-attachment created + ├─ aws:iam:RolePolicyAttachment eks-cluster-policy-attachment created + ├─ aws:ec2:InternetGateway vpc-ig created + ├─ aws:ec2:Subnet vpc-sn-1 created + ├─ aws:ec2:Subnet vpc-sn-2 created + ├─ aws:ec2:SecurityGroup eks-cluster-sg created + ├─ aws:ec2:RouteTable vpc-route-table created + ├─ aws:eks:Cluster eks-cluster created + ├─ aws:ec2:RouteTableAssociation vpc-1-route-table-assoc created + ├─ aws:ec2:RouteTableAssociation vpc-2-route-table-assoc created + └─ aws:eks:NodeGroup eks-node-group created Outputs: cluster-name: "eks-cluster-96b87e8" Resources: + 18 created Duration: 14m15s
-
View the cluster name via
stack output
:$ pulumi stack output Current stack outputs (1): OUTPUT VALUE cluster-name eks-cluster-96b87e8
-
Verify that the EKS cluster exists, by either using the AWS Console or running
aws eks list-clusters
. -
Update your KubeConfig, Authenticate to your Kubernetes Cluster and verify you have API access and nodes running.
$ aws eks --region us-east-2 update-kubeconfig --name $(pulumi stack output cluster-name)
Added new context arn:aws:eks:us-east-2:account:cluster/eks-cluster-96b87e8
$ kubectl get nodes
NAME STATUS ROLES AGE VERSION
ip-10-100-0-182.us-east-2.compute.internal Ready <none> 10m v1.14.7-eks-1861c5
ip-10-100-1-174.us-east-2.compute.internal Ready <none> 10m v1.14.7-eks-1861c5
To clean up resources, run pulumi destroy
and answer the confirmation question at the prompt.