Skip to content

Commit

Permalink
Machine deletion: try up to 10s to delete the Node, then move on
Browse files Browse the repository at this point in the history
  • Loading branch information
tahsinrahman committed Sep 26, 2019
1 parent 92ed320 commit 3119c2c
Showing 1 changed file with 11 additions and 3 deletions.
14 changes: 11 additions & 3 deletions controllers/machine_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ package controllers
import (
"context"
"sync"
"time"

"github.com/go-logr/logr"
"github.com/pkg/errors"
Expand All @@ -27,6 +28,7 @@ import (
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
kerrors "k8s.io/apimachinery/pkg/util/errors"
"k8s.io/apimachinery/pkg/util/wait"
"k8s.io/client-go/tools/record"
"k8s.io/klog"
clusterv1 "sigs.k8s.io/cluster-api/api/v1alpha2"
Expand Down Expand Up @@ -183,9 +185,15 @@ func (r *MachineReconciler) reconcileDelete(ctx context.Context, cluster *cluste
}
} else {
klog.Infof("Deleting node %q for machine %q", m.Status.NodeRef.Name, m.Name)
if err := r.deleteNode(ctx, cluster, m.Status.NodeRef.Name); err != nil && !apierrors.IsNotFound(err) {
klog.Errorf("Error deleting node %q for machine %q: %v", m.Status.NodeRef.Name, m.Name, err)
return ctrl.Result{}, err
waitErr := wait.PollImmediate(2*time.Second, 10*time.Second, func() (bool, error) {
if err = r.deleteNode(ctx, cluster, m.Status.NodeRef.Name); err != nil && !apierrors.IsNotFound(err) {
return false, nil
}
return true, nil
})
if waitErr != nil {
r.Log.Error(err, "timed out deleting Machine's node, moving on", "node", m.Status.NodeRef.Name, "machine", m.Name)
r.recorder.Eventf(m, corev1.EventTypeWarning, "FailedDelete", "timedout deleting Machine's node: %v", err)
}
}

Expand Down

0 comments on commit 3119c2c

Please sign in to comment.