Skip to content

Commit

Permalink
Don't orphan inactive replica directories if there is no active count…
Browse files Browse the repository at this point in the history
…erpart

Longhorn 6961

Signed-off-by: Eric Weber <[email protected]>
  • Loading branch information
ejweber committed Oct 31, 2023
1 parent 14490e1 commit c471422
Showing 1 changed file with 16 additions and 1 deletion.
17 changes: 16 additions & 1 deletion controller/replica_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -303,11 +303,17 @@ func (rc *ReplicaController) syncReplica(key string) (err error) {
return errors.Wrapf(err, "failed to cleanup the related replica instance before deleting replica %v", replica.Name)
}

rs, err := rc.ds.ListReplicasByNodeRO(replica.Spec.NodeID)
if err != nil {
return errors.Wrapf(err, "failed to list replicas by node before deleting replica %v", replica.Name)
}

if replica.Spec.NodeID != "" && replica.Spec.NodeID != rc.controllerID {
log.Warn("Failed to cleanup replica's data because the replica's data is not on this node")
} else if replica.Spec.NodeID != "" {
if replica.Spec.BackendStoreDriver == longhorn.BackendStoreDriverTypeV1 {
if replica.Spec.Active && dataPath != "" {
// Clean up the data directory if this is the active replica or if there is no matching replica.
if (replica.Spec.Active || !hasMatchingReplica(replica, rs)) && dataPath != "" {
// prevent accidentally deletion
if !strings.Contains(filepath.Base(filepath.Clean(dataPath)), "-") {
return fmt.Errorf("%v doesn't look like a replica data path", dataPath)
Expand Down Expand Up @@ -937,3 +943,12 @@ func (rc *ReplicaController) enqueueAllRebuildingReplicaOnCurrentNode() {
func (rc *ReplicaController) isResponsibleFor(r *longhorn.Replica) bool {
return isControllerResponsibleFor(rc.controllerID, rc.ds, r.Name, r.Spec.NodeID, r.Status.OwnerID)
}

func hasMatchingReplica(replica *longhorn.Replica, replicas []*longhorn.Replica) bool {
for _, r := range replicas {
if r.Name != replica.Name && r.Spec.DataDirectoryName == replica.Spec.DataDirectoryName {
return true
}
}
return false
}

0 comments on commit c471422

Please sign in to comment.