Browse Source

volume: avoid deadlock when deleting volumes

fix https://github.com/chrislusf/seaweedfs/issues/1501
pull/1508/head
Chris Lu 4 years ago
parent
commit
a1c01d716b
  1. 3
      weed/storage/disk_location.go
  2. 4
      weed/storage/store.go

3
weed/storage/disk_location.go

@ -174,9 +174,6 @@ func (l *DiskLocation) DeleteCollectionFromDiskLocation(collection string) (e er
} }
func (l *DiskLocation) deleteVolumeById(vid needle.VolumeId) (found bool, e error) { func (l *DiskLocation) deleteVolumeById(vid needle.VolumeId) (found bool, e error) {
l.volumesLock.Lock()
defer l.volumesLock.Unlock()
v, ok := l.volumes[vid] v, ok := l.volumes[vid]
if !ok { if !ok {
return return

4
weed/storage/store.go

@ -380,10 +380,12 @@ func (s *Store) DeleteVolume(i needle.VolumeId) error {
Ttl: v.Ttl.ToUint32(), Ttl: v.Ttl.ToUint32(),
} }
for _, location := range s.Locations { for _, location := range s.Locations {
if found, err := location.deleteVolumeById(i); found && err == nil {
if err := location.DeleteVolume(i); err == nil {
glog.V(0).Infof("DeleteVolume %d", i) glog.V(0).Infof("DeleteVolume %d", i)
s.DeletedVolumesChan <- message s.DeletedVolumesChan <- message
return nil return nil
} else {
glog.Errorf("DeleteVolume %d: %v", i, err)
} }
} }

Loading…
Cancel
Save