Skip to content

Commit

Permalink
Use new CoreDNS manifests
Browse files Browse the repository at this point in the history
  • Loading branch information
errordeveloper committed Jun 12, 2019
1 parent bfc5fea commit 997eb59
Show file tree
Hide file tree
Showing 3 changed files with 70 additions and 38 deletions.
92 changes: 57 additions & 35 deletions pkg/addons/default/coredns.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,17 +8,15 @@ import (
"github.com/kris-nova/logger"
"github.com/pkg/errors"

appsv1 "k8s.io/api/apps/v1"
corev1 "k8s.io/api/core/v1"
extensionsv1beta1 "k8s.io/api/extensions/v1beta1"
apierrs "k8s.io/apimachinery/pkg/api/errors"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/labels"
"k8s.io/apimachinery/pkg/util/sets"
"k8s.io/apimachinery/pkg/watch"

"github.com/weaveworks/eksctl/pkg/kubernetes"
"github.com/weaveworks/eksctl/pkg/printers"
k8s "k8s.io/client-go/kubernetes"
)

const (
Expand All @@ -27,17 +25,14 @@ const (
// KubeDNS is the name of the kube-dns addon
KubeDNS = "kube-dns"

// CoreDNSVersion Current latest coredns version supported
CoreDNSVersion = "v1.2.2"

componentLabel = "eks.amazonaws.com/component"

coreDNSImagePrefix = "602401143452.dkr.ecr."
coreDNSImageSuffix = ".amazonaws.com/eks/coredns"
)

// InstallCoreDNS will install the `coredns` add-on in place of `kube-dns`
func InstallCoreDNS(rawClient kubernetes.RawClientInterface, region string, waitTimeout *time.Duration, plan bool) (bool, error) {
func InstallCoreDNS(rawClient kubernetes.RawClientInterface, region, controlPlaneVersion string, waitTimeout *time.Duration, plan bool) (bool, error) {
kubeDNSSevice, err := rawClient.ClientSet().CoreV1().Services(metav1.NamespaceSystem).Get(KubeDNS, metav1.GetOptions{})
if err != nil {
if apierrs.IsNotFound(err) {
Expand Down Expand Up @@ -67,7 +62,7 @@ func InstallCoreDNS(rawClient kubernetes.RawClientInterface, region string, wait
}

// if kube-dns is present, go ahead and try to replace it with coredns
list, err := LoadAsset(CoreDNS, "yaml")
list, err := loadAssetCoreDNS(controlPlaneVersion)
if err != nil {
return false, err
}
Expand All @@ -81,7 +76,7 @@ func InstallCoreDNS(rawClient kubernetes.RawClientInterface, region string, wait
}
switch resource.GVK.Kind {
case "Deployment":
coreDNSDeployemnt := resource.Info.Object.(*extensionsv1beta1.Deployment)
coreDNSDeployemnt := resource.Info.Object.(*appsv1.Deployment)
listPodsOptions.LabelSelector = labels.FormatLabels(coreDNSDeployemnt.Spec.Selector.MatchLabels)
replicas = int(*coreDNSDeployemnt.Spec.Replicas)
image := &coreDNSDeployemnt.Spec.Template.Spec.Containers[0].Image
Expand Down Expand Up @@ -167,54 +162,81 @@ func InstallCoreDNS(rawClient kubernetes.RawClientInterface, region string, wait
return false, nil
}

// UpdateCoreDNSImageTag updates image tag for kube-system:deployment/coredns based to match the latest release
func UpdateCoreDNSImageTag(clientSet k8s.Interface, plan bool) (bool, error) {
printer := printers.NewJSONPrinter()
// UpdateCoreDNS will update the `coredns` add-on
func UpdateCoreDNS(rawClient kubernetes.RawClientInterface, region, controlPlaneVersion string, plan bool) (bool, error) {
kubeDNSSevice, err := rawClient.ClientSet().CoreV1().Services(metav1.NamespaceSystem).Get(KubeDNS, metav1.GetOptions{})
if err != nil {
if apierrs.IsNotFound(err) {
logger.Warning("%q service was not found", KubeDNS)
return false, nil
}
return false, errors.Wrapf(err, "getting %q service", KubeDNS)
}

d, err := clientSet.AppsV1().Deployments(metav1.NamespaceSystem).Get(CoreDNS, metav1.GetOptions{})
_, err = rawClient.ClientSet().AppsV1().Deployments(metav1.NamespaceSystem).Get(CoreDNS, metav1.GetOptions{})
if err != nil {
if apierrs.IsNotFound(err) {
logger.Warning("%q was not found", CoreDNS)
return false, nil
}
return false, errors.Wrapf(err, "getting %q", CoreDNS)
}
if numContainers := len(d.Spec.Template.Spec.Containers); !(numContainers >= 1) {
return false, fmt.Errorf("%s has %d containers, expected at least 1", CoreDNS, numContainers)
}

if err := printer.LogObj(logger.Debug, CoreDNS+" [current] = \\\n%s\n", d); err != nil {
// if Deployment is present, go through our list of assets
list, err := loadAssetCoreDNS(controlPlaneVersion)
if err != nil {
return false, err
}

image := &d.Spec.Template.Spec.Containers[0].Image
imageParts := strings.Split(*image, ":")
for _, rawObj := range list.Items {
resource, err := rawClient.NewRawResource(rawObj)
if err != nil {
return false, err
}
switch resource.GVK.Kind {
case "Deployment":
image := &resource.Info.Object.(*appsv1.Deployment).Spec.Template.Spec.Containers[0].Image
imageParts := strings.Split(*image, ":")

if len(imageParts) != 2 {
return false, fmt.Errorf("unexpected image format %q for %q", *image, CoreDNS)
}
if len(imageParts) != 2 {
return false, fmt.Errorf("unexpected image format %q for %q", *image, KubeProxy)
}

if imageParts[1] == CoreDNSVersion {
logger.Debug("imageParts = %v, desiredTag = %s", imageParts, CoreDNSVersion)
logger.Info("%q is already up-to-date", CoreDNS)
return false, nil
if strings.HasPrefix(imageParts[0], coreDNSImagePrefix) &&
strings.HasSuffix(imageParts[0], coreDNSImageSuffix) {
*image = coreDNSImagePrefix + region + coreDNSImageSuffix + ":" + imageParts[1]
}
case "Service":
resource.Info.Object.(*corev1.Service).SetResourceVersion(kubeDNSSevice.GetResourceVersion())
resource.Info.Object.(*corev1.Service).Spec.ClusterIP = kubeDNSSevice.Spec.ClusterIP
}

status, err := resource.CreateOrReplace(plan)
if err != nil {
return false, err
}
logger.Info(status)
}

if plan {
logger.Critical("(plan) %q is not up-to-date", CoreDNS)
return true, nil
}

imageParts[1] = CoreDNSVersion
*image = strings.Join(imageParts, ":")
logger.Info("%q is now up-to-date", CoreDNS)
return false, nil
}

if err := printer.LogObj(logger.Debug, CoreDNS+" [updated] = \\\n%s\n", d); err != nil {
return false, err
func loadAssetCoreDNS(controlPlaneVersion string) (*metav1.List, error) {
assetName := CoreDNS
if strings.HasPrefix(controlPlaneVersion, "1.10.") {
return nil, fmt.Errorf("CoreDNS is not supported on Kubernetes 1.10")
}
if _, err := clientSet.AppsV1().Deployments(metav1.NamespaceSystem).Update(d); err != nil {
return false, err
if strings.HasPrefix(controlPlaneVersion, "1.11.") {
assetName += "-1.11"
}

logger.Info("%q is now up-to-date", CoreDNS)
return false, nil
if strings.HasPrefix(controlPlaneVersion, "1.12.") {
assetName += "-1.12"
}
return LoadAsset(assetName, "json")
}
7 changes: 6 additions & 1 deletion pkg/ctl/utils/install_corends.go
Original file line number Diff line number Diff line change
Expand Up @@ -69,9 +69,14 @@ func doInstallCoreDNS(rc *cmdutils.ResourceCmd) error {
return err
}

kubernetesVersion, err := rawClient.ServerVersion()
if err != nil {
return err
}

waitTimeout := ctl.Provider.WaitTimeout()

updateRequired, err := defaultaddons.InstallCoreDNS(rawClient, meta.Region, &waitTimeout, rc.Plan)
updateRequired, err := defaultaddons.InstallCoreDNS(rawClient, meta.Region, kubernetesVersion, &waitTimeout, rc.Plan)
if err != nil {
return err
}
Expand Down
9 changes: 7 additions & 2 deletions pkg/ctl/utils/update_coredns.go
Original file line number Diff line number Diff line change
Expand Up @@ -54,12 +54,17 @@ func doUpdateCoreDNS(rc *cmdutils.ResourceCmd) error {
return errors.Wrapf(err, "getting credentials for cluster %q", meta.Name)
}

clientSet, err := ctl.NewStdClientSet(cfg)
rawClient, err := ctl.NewRawClient(cfg)
if err != nil {
return err
}

updateRequired, err := defaultaddons.UpdateCoreDNSImageTag(clientSet, rc.Plan)
kubernetesVersion, err := rawClient.ServerVersion()
if err != nil {
return err
}

updateRequired, err := defaultaddons.UpdateCoreDNS(rawClient, meta.Region, kubernetesVersion, rc.Plan)
if err != nil {
return err
}
Expand Down

0 comments on commit 997eb59

Please sign in to comment.