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 Nov 2, 2023
1 parent 13818a5 commit 5326131
Showing 1 changed file with 17 additions and 1 deletion.
18 changes: 17 additions & 1 deletion controller/replica_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -303,11 +303,18 @@ 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 this inactive replica is the only one
// using it.
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 +944,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 5326131

Please sign in to comment.