Browse Source

Merge branch 'master' into msg_channel

pull/1318/head
Chris Lu 5 years ago
parent
commit
d58371c5cd
  1. 16
      weed/filer2/filer_deletion.go

16
weed/filer2/filer_deletion.go

@ -34,12 +34,23 @@ func (f *Filer) loopProcessingDeletion() {
lookupFunc := LookupByMasterClientFn(f.MasterClient) lookupFunc := LookupByMasterClientFn(f.MasterClient)
DeletionBatchSize := 100000 // roughly 20 bytes cost per file id.
var deletionCount int var deletionCount int
for { for {
deletionCount = 0 deletionCount = 0
f.fileIdDeletionQueue.Consume(func(fileIds []string) { f.fileIdDeletionQueue.Consume(func(fileIds []string) {
deletionCount = len(fileIds)
deleteResults, err := operation.DeleteFilesWithLookupVolumeId(f.GrpcDialOption, fileIds, lookupFunc)
for len(fileIds) > 0 {
var toDeleteFileIds []string
if len(fileIds) > DeletionBatchSize {
toDeleteFileIds = fileIds[:DeletionBatchSize]
fileIds = fileIds[DeletionBatchSize:]
} else {
toDeleteFileIds = fileIds
fileIds = fileIds[:0]
}
deletionCount = len(toDeleteFileIds)
deleteResults, err := operation.DeleteFilesWithLookupVolumeId(f.GrpcDialOption, toDeleteFileIds, lookupFunc)
if err != nil { if err != nil {
glog.V(0).Infof("deleting fileIds len=%d error: %v", deletionCount, err) glog.V(0).Infof("deleting fileIds len=%d error: %v", deletionCount, err)
} else { } else {
@ -48,6 +59,7 @@ func (f *Filer) loopProcessingDeletion() {
if len(deleteResults) != deletionCount { if len(deleteResults) != deletionCount {
glog.V(0).Infof("delete %d fileIds actual %d", deletionCount, len(deleteResults)) glog.V(0).Infof("delete %d fileIds actual %d", deletionCount, len(deleteResults))
} }
}
}) })
if deletionCount == 0 { if deletionCount == 0 {

Loading…
Cancel
Save