From 99d8a2a47f08a70f5c8b168d3ca5697444c2bba0 Mon Sep 17 00:00:00 2001 From: Yihan Song Date: Wed, 11 Mar 2020 11:17:26 +0800 Subject: [PATCH] Add failback logic when working on k8s 1.16+ It would fail due to `the server could not find the requested resource` which access a non-valid versioning namespace for deployment --- pkg/util/k8sutil/vault.go | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/pkg/util/k8sutil/vault.go b/pkg/util/k8sutil/vault.go index 44c6cb8..7f4021b 100644 --- a/pkg/util/k8sutil/vault.go +++ b/pkg/util/k8sutil/vault.go @@ -28,7 +28,7 @@ import ( "github.com/coreos/etcd-operator/pkg/util/retryutil" vaultapi "github.com/hashicorp/vault/api" appsv1beta1 "k8s.io/api/apps/v1beta1" - "k8s.io/api/core/v1" + v1 "k8s.io/api/core/v1" apierrors "k8s.io/apimachinery/pkg/api/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/util/intstr" @@ -283,7 +283,17 @@ func DeployVault(kubecli kubernetes.Interface, v *api.VaultService) error { AddOwnerRefToObject(d, AsOwner(v)) _, err := kubecli.AppsV1beta1().Deployments(v.Namespace).Create(d) if err != nil && !apierrors.IsAlreadyExists(err) { - return err + // after 1.15, the deployment moves to v1 per https://v1-16.docs.kubernetes.io/zh/docs/concepts/workloads/controllers/deployment/ + if !apierrors.IsNotFound(err) { + return err + } + + // then try fail back on different versioning namespace + _, err = kubecli.AppsV1().Deployments(v.Namespace).Create(d) + + if err != nil && !apierrors.IsAlreadyExists(err) { + return err + } } svc := &v1.Service{