Help improve this page
Want to contribute to this user guide? Scroll to the bottom of this page and select Edit this page on GitHub. Your contributions will help make our user guide better for everyone.
Manage CoreDNS for DNS in Amazon EKS clusters
CoreDNS is a flexible, extensible DNS server that can serve as the Kubernetes cluster DNS.
When you launch an Amazon EKS cluster with at least one node, two replicas of the CoreDNS image
are deployed by default, regardless of the number of nodes deployed in your cluster. The
CoreDNS Pods provide name resolution for all Pods in the
cluster. The CoreDNS Pods can be deployed to Fargate nodes if your
cluster includes an Define which Pods use AWS Fargate when
launched with a
namespace that matches the namespace for the CoreDNS deployment
. For more
information about CoreDNS, see Using CoreDNS for
Service Discovery
CoreDNS versions
The following table lists the latest version of the Amazon EKS add-on type for each Kubernetes version.
Kubernetes version | 1.30 |
1.29 |
1.28 |
1.27 |
1.26 |
1.25 |
1.24 |
1.23 |
---|---|---|---|---|---|---|---|---|
v1.11.1-eksbuild.11 |
v1.11.1-eksbuild.11 |
v1.10.1-eksbuild.13 |
v1.10.1-eksbuild.13 |
v1.9.3-eksbuild.17 |
v1.9.3-eksbuild.17 |
v1.9.3-eksbuild.17 |
v1.8.7-eksbuild.16 |
Important
If you're self-managing this add-on, the versions in the table might not be the same as the available self-managed versions. For more information about updating the self-managed type of this add-on, see Update the CoreDNS Amazon EKS self-managed add-on.
Important CoreDNS upgrade considerations
-
To improve the stability and availability of the CoreDNS Deployment, versions
v1.9.3-eksbuild.6
and later andv1.10.1-eksbuild.3
are deployed with aPodDisruptionBudget
. If you've deployed an existingPodDisruptionBudget
, your upgrade to these versions might fail. If the upgrade fails, completing one of the following tasks should resolve the issue:-
When doing the upgrade of the Amazon EKS add-on, choose to override the existing settings as your conflict resolution option. If you've made other custom settings to the Deployment, make sure to back up your settings before upgrading so that you can reapply your other custom settings after the upgrade.
-
Remove your existing
PodDisruptionBudget
and try the upgrade again.
-
-
In EKS add-on versions
v1.9.3-eksbuild.3
and later andv1.10.1-eksbuild.6
and later, the CoreDNS Deployment sets thereadinessProbe
to use the/ready
endpoint. This endpoint is enabled in theCorefile
configuration file for CoreDNS.If you use a custom
Corefile
, you must add theready
plugin to the config, so that the/ready
endpoint is active in CoreDNS for the probe to use. -
In EKS add-on versions
v1.9.3-eksbuild.7
and later andv1.10.1-eksbuild.4
and later, you can change thePodDisruptionBudget
. You can edit the add-on and change these settings in the Optional configuration settings using the fields in the following example. This example shows the defaultPodDisruptionBudget
.{ "podDisruptionBudget": { "enabled": true, "maxUnavailable": 1 } }
You can set
maxUnavailable
orminAvailable
, but you can't set both in a singlePodDisruptionBudget
. For more information aboutPodDisruptionBudgets
, see Specifying aPodDisruptionBudget
in the Kubernetes documentation. Note that if you set
enabled
tofalse
, thePodDisruptionBudget
isn't removed. After you set this field tofalse
, you must delete thePodDisruptionBudget
object. Similarly, if you edit the add-on to use an older version of the add-on (downgrade the add-on) after upgrading to a version with aPodDisruptionBudget
, thePodDisruptionBudget
isn't removed. To delete thePodDisruptionBudget
, you can run the following command:kubectl delete poddisruptionbudget coredns -n kube-system
-
In EKS add-on versions
v1.10.1-eksbuild.5
and later, change the default toleration fromnode-role.kubernetes.io/master:NoSchedule
tonode-role.kubernetes.io/control-plane:NoSchedule
to comply with KEP 2067. For more information about KEP 2067, see KEP-2067: Rename the kubeadm "master" label and taintin the Kubernetes Enhancement Proposals (KEPs) on GitHub. In EKS add-on versions
v1.8.7-eksbuild.8
and later andv1.9.3-eksbuild.9
and later, both tolerations are set to be compatible with every Kubernetes version. -
In EKS add-on versions
v1.9.3-eksbuild.11
andv1.10.1-eksbuild.7
and later, the CoreDNS Deployment sets a default value fortopologySpreadConstraints
. The default value ensures that the CoreDNS Pods are spread across the Availability Zones if there are nodes in multiple Availability Zones available. You can set a custom value that will be used instead of the default value. The default value follows:topologySpreadConstraints: - maxSkew: 1 topologyKey: topology.kubernetes.io/zone whenUnsatisfiable: ScheduleAnyway labelSelector: matchLabels: k8s-app: kube-dns
CoreDNS v1.11
upgrade considerations
-
In EKS add-on versions
v1.11.1-eksbuild.4
and later, the container image is based on a minimal base imagemaintained by Amazon EKS Distro, which contains minimal packages and doesn't have shells. For more information, see Amazon EKS Distro . The usage and troubleshooting of the CoreDNS image remains the same.