AWS Elastic Kubernetes Service (EKS) sandbox
Workshop - https://www.eksworkshop.com/docs/introduction/
Pricing
Static cost of a cluster is $0.1 per hour, so ~$70 per month.
In extended support (old k8s versions), each cluster costs $0.6 per hours (6x), so ~$420 per month.
Update kubeconfig
to access EKS
aws eks update-kubeconfig --name my-cluster --region us-east-1
If cluster admin role is different from current role used to aut
aws eks update-kubeconfig --name my-cluster --role-arn arn:aws:iam::123456789000:role/eksrole --region us-east-1
More here - https://docs.aws.amazon.com/eks/latest/userguide/create-kubeconfig.html
Workload AWS access
Provide access to AWS workloads like S3 buckets, SNS topics etc via short lived temporary credentials.
IRSA (IAM roles for service accounts)
Pods can use service accounts which was backed by IAM roles and their permissions. Needs an annotation on k8s service account which refers to the IAM role arn. Principal in the role’s trust policy is the EKS cluster’s oidc provider.
You can add conditions to lock down which service accounts are able to use this role.
annotation: eks.amazonaws.com/role-arn: arn:aws:iam::111122223333:role/my-role
Example trust policy
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Principal": {
"Federated": "arn:aws:iam::111122223333:oidc-provider/oidc.eks.region-code.amazonaws.com/id/EXAMPLED539D4633E53DE1B71EXAMPLE"
},
"Action": "sts:AssumeRoleWithWebIdentity",
"Condition": {
"StringEquals": {
"oidc.eks.region-code.amazonaws.com/id/EXAMPLED539D4633E53DE1B71EXAMPLE:sub": "system:serviceaccount:default:my-service-account",
"oidc.eks.region-code.amazonaws.com/id/EXAMPLED539D4633E53DE1B71EXAMPLE:aud": "sts.amazonaws.com"
}
}
}
]
}
More here https://docs.aws.amazon.com/eks/latest/userguide/associate-service-account-role.html
Pod Identities
Pods can assume an IAM role directly via k8s service account, without the need of an annotation on the service account. It need a pod identity association at cluster level (needs namespace, service account name). An agent runs on each node which makes this possible. The role’s trust policy is different than when using IRSA. The principal here is service: pods.eks.amazonaws.com
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "AllowEksAuthToAssumeRoleForPodIdentity",
"Effect": "Allow",
"Principal": {
"Service": "pods.eks.amazonaws.com"
},
"Action": [
"sts:AssumeRole",
"sts:TagSession"
]
}
]
}
Following cdk code snippet (typescript) creates such a role, and adds a pod identity association.
const podIdentityServicePrincipal = new iam.SessionTagsPrincipal(new iam.ServicePrincipal("pods.eks.amazonaws.com"))
const workloadPodIdentityRole = new iam.Role(this, "WorkloadPodIdentityRole", {
assumedBy: podIdentityServicePrincipal,
});
workloadPolicy.attachToRole(WorkloadPodIdentityRole);
new eks.CfnPodIdentityAssociation(this, "WorkloadPodIdentityRoleAssociation", {
clusterName: cluster.clusterName,
roleArn: workloadPodIdentityRole.roleArn,
namespace: "workload",
serviceAccount: "workload-podidentity",
});
Networking
https://aws.github.io/aws-eks-best-practices/networking/
https://github.com/aws/amazon-vpc-cni-k8s
Advanced Networking
https://aws.amazon.com/blogs/containers/eks-vpc-routable-ip-address-conservation/
- can use both Fargate and EC2 clusters to launch nodes.
- STS endpoint for the deployment region must be enabled.
- worker nodes must have a private DNS entry or a node not found error will occur.
- node IAM role must be present in the aws-auth-cm.yaml file when using self-managed Amazon Linux nodes.
Ref: https://docs.aws.amazon.com/eks/latest/userguide/troubleshooting.html, https://docs.aws.amazon.com/eks/latest/userguide/eks-connector.html
Add-ons
Fetch available config options via aws cli
$ aws eks describe-addon-versions --addon-name vpc-cni # provides available versions
$ aws eks describe-addon-configuration --addon-name vpc-cni --addon-version v1.12.0-eksbuild.1 # provides config options under configurationSchema
{
"addonName": "vpc-cni",
"addonVersion": "v1.12.0-eksbuild.1",
"configurationSchema": "{\"$ref\":\"#/definitions/VpcCni\",\"$schema\":\"http://json-schema.org/draft-06/schema#\",\"definitions\":{\"Cri\":{\"additionalProperties\":false,\"properties\":{\"hostPath\":{\"$ref\":\"#/definitions/HostPath\"}},\"title\":\"Cri\",\"type\":\"object\"},\"Env\":{\"additionalProperties\":false,\"properties\":{\"ADDITIONAL_ENI_TAGS\":{\"type\":\"string\"},\"AWS_VPC_CNI_NODE_PORT_SUPPORT\":{\"format\":\"boolean\",\"type\":\"string\"},\"AWS_VPC_ENI_MTU\":{\"format\":\"integer\",\"type\":\"string\"},\"AWS_VPC_K8S_CNI_CONFIGURE_RPFILTER\":{\"format\":\"boolean\",\"type\":\"string\"},\"AWS_VPC_K8S_CNI_CUSTOM_NETWORK_CFG\":{\"format\":\"boolean\",\"type\":\"string\"},\"AWS_VPC_K8S_CNI_EXTERNALSNAT\":{\"format\":\"boolean\",\"type\":\"string\"},\"AWS_VPC_K8S_CNI_LOGLEVEL\":{\"type\":\"string\"},\"AWS_VPC_K8S_CNI_LOG_FILE\":{\"type\":\"string\"},\"AWS_VPC_K8S_CNI_RANDOMIZESNAT\":{\"type\":\"string\"},\"AWS_VPC_K8S_CNI_VETHPREFIX\":{\"type\":\"string\"},\"AWS_VPC_K8S_PLUGIN_LOG_FILE\":{\"type\":\"string\"},\"AWS_VPC_K8S_PLUGIN_LOG_LEVEL\":{\"type\":\"string\"},\"DISABLE_INTROSPECTION\":{\"format\":\"boolean\",\"type\":\"string\"},\"DISABLE_METRICS\":{\"format\":\"boolean\",\"type\":\"string\"},\"DISABLE_NETWORK_RESOURCE_PROVISIONING\":{\"format\":\"boolean\",\"type\":\"string\"},\"ENABLE_POD_ENI\":{\"format\":\"boolean\",\"type\":\"string\"},\"ENABLE_PREFIX_DELEGATION\":{\"format\":\"boolean\",\"type\":\"string\"},\"WARM_ENI_TARGET\":{\"format\":\"integer\",\"type\":\"string\"},\"WARM_PREFIX_TARGET\":{\"format\":\"integer\",\"type\":\"string\"}},\"title\":\"Env\",\"type\":\"object\"},\"HostPath\":{\"additionalProperties\":false,\"properties\":{\"path\":{\"type\":\"string\"}},\"title\":\"HostPath\",\"type\":\"object\"},\"Limits\":{\"additionalProperties\":false,\"properties\":{\"cpu\":{\"type\":\"string\"},\"memory\":{\"type\":\"string\"}},\"title\":\"Limits\",\"type\":\"object\"},\"Resources\":{\"additionalProperties\":false,\"properties\":{\"limits\":{\"$ref\":\"#/definitions/Limits\"},\"requests\":{\"$ref\":\"#/definitions/Limits\"}},\"title\":\"Resources\",\"type\":\"object\"},\"VpcCni\":{\"additionalProperties\":false,\"properties\":{\"cri\":{\"$ref\":\"#/definitions/Cri\"},\"env\":{\"$ref\":\"#/definitions/Env\"},\"resources\":{\"$ref\":\"#/definitions/Resources\"}},\"title\":\"VpcCni\",\"type\":\"object\"}}}"
}
Find all available versions, along with supported k8s versions
$ aws eks describe-addon-versions --addon-name aws-efs-csi-driver | jq -cr '.addons[0].addonVersions[]| [.addonVersion,.compatibilities[].clusterVersion] | @csv'
"v2.0.7-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v2.0.6-eksbuild.2","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v2.0.6-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v2.0.5-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v2.0.4-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v2.0.3-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v2.0.2-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v2.0.1-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v2.0.0-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v1.7.7-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v1.7.6-eksbuild.2","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v1.7.6-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v1.7.5-eksbuild.2","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v1.7.5-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v1.7.4-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v1.7.3-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v1.7.2-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v1.7.1-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v1.7.0-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v1.5.9-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23"
"v1.5.8-eksbuild.1","1.30","1.29","1.28","1.27","1.26","1.25","1.24","1.23","1.22"
Kubecost
Mix of enterprise and opensource features at no additional cost.
Comparison here.