aboutsummaryrefslogtreecommitdiff
path: root/weed/shell/command_volume_fix_replication.go
diff options
context:
space:
mode:
authorchrislu <chris.lu@gmail.com>2022-08-22 14:12:23 -0700
committerchrislu <chris.lu@gmail.com>2022-08-22 14:12:23 -0700
commit676e27c589a99691ba78f010a067898d89f764ac (patch)
treecee659e16990e035b0f7a3c2ed994f1ea77cf9c2 /weed/shell/command_volume_fix_replication.go
parent601ba5fb680eb028080160c857feda9b7044ab56 (diff)
downloadseaweedfs-676e27c589a99691ba78f010a067898d89f764ac.tar.xz
seaweedfs-676e27c589a99691ba78f010a067898d89f764ac.zip
shell: stop long running jobs if lock is lost
Diffstat (limited to 'weed/shell/command_volume_fix_replication.go')
-rw-r--r--weed/shell/command_volume_fix_replication.go4
1 files changed, 4 insertions, 0 deletions
diff --git a/weed/shell/command_volume_fix_replication.go b/weed/shell/command_volume_fix_replication.go
index 247627839..5cc4ba645 100644
--- a/weed/shell/command_volume_fix_replication.go
+++ b/weed/shell/command_volume_fix_replication.go
@@ -104,6 +104,10 @@ func (c *commandVolumeFixReplication) Do(args []string, commandEnv *CommandEnv,
}
}
+ if !commandEnv.isLocked() {
+ return fmt.Errorf("lock is lost")
+ }
+
if len(overReplicatedVolumeIds) > 0 {
if err := c.deleteOneVolume(commandEnv, writer, takeAction, overReplicatedVolumeIds, volumeReplicas, allLocations, pickOneReplicaToDelete); err != nil {
return err