mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2025-12-17 17:51:20 +08:00
s3: batch purge empty folders
This commit is contained in:
@@ -175,16 +175,15 @@ func (s3a *S3ApiServer) DeleteMultipleObjectsHandler(w http.ResponseWriter, r *h
|
|||||||
var deletedObjects []ObjectIdentifier
|
var deletedObjects []ObjectIdentifier
|
||||||
var deleteErrors []DeleteError
|
var deleteErrors []DeleteError
|
||||||
|
|
||||||
|
directoriesWithDeletion := make(map[string]int)
|
||||||
|
|
||||||
s3a.WithFilerClient(func(client filer_pb.SeaweedFilerClient) error {
|
s3a.WithFilerClient(func(client filer_pb.SeaweedFilerClient) error {
|
||||||
|
|
||||||
|
// delete file entries
|
||||||
for _, object := range deleteObjects.Objects {
|
for _, object := range deleteObjects.Objects {
|
||||||
response, _ := s3a.listFilerEntries(bucket, object.ObjectName, 1, "", "/")
|
|
||||||
if len(response.Contents) != 0 && strings.HasSuffix(object.ObjectName, "/") {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
lastSeparator := strings.LastIndex(object.ObjectName, "/")
|
lastSeparator := strings.LastIndex(object.ObjectName, "/")
|
||||||
parentDirectoryPath, entryName, isDeleteData, isRecursive := "/", object.ObjectName, true, true
|
parentDirectoryPath, entryName, isDeleteData, isRecursive := "/", object.ObjectName, true, false
|
||||||
if lastSeparator > 0 && lastSeparator+1 < len(object.ObjectName) {
|
if lastSeparator > 0 && lastSeparator+1 < len(object.ObjectName) {
|
||||||
entryName = object.ObjectName[lastSeparator+1:]
|
entryName = object.ObjectName[lastSeparator+1:]
|
||||||
parentDirectoryPath = "/" + object.ObjectName[:lastSeparator]
|
parentDirectoryPath = "/" + object.ObjectName[:lastSeparator]
|
||||||
@@ -193,8 +192,10 @@ func (s3a *S3ApiServer) DeleteMultipleObjectsHandler(w http.ResponseWriter, r *h
|
|||||||
|
|
||||||
err := doDeleteEntry(client, parentDirectoryPath, entryName, isDeleteData, isRecursive)
|
err := doDeleteEntry(client, parentDirectoryPath, entryName, isDeleteData, isRecursive)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
|
directoriesWithDeletion[parentDirectoryPath]++
|
||||||
deletedObjects = append(deletedObjects, object)
|
deletedObjects = append(deletedObjects, object)
|
||||||
} else {
|
} else {
|
||||||
|
delete(directoriesWithDeletion, parentDirectoryPath)
|
||||||
deleteErrors = append(deleteErrors, DeleteError{
|
deleteErrors = append(deleteErrors, DeleteError{
|
||||||
Code: "",
|
Code: "",
|
||||||
Message: err.Error(),
|
Message: err.Error(),
|
||||||
@@ -202,6 +203,15 @@ func (s3a *S3ApiServer) DeleteMultipleObjectsHandler(w http.ResponseWriter, r *h
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// purge empty folders, only checking folders with deletions
|
||||||
|
for dir, deletionCount := range directoriesWithDeletion {
|
||||||
|
parentDir, dirName := util.FullPath(dir).DirAndName()
|
||||||
|
if err := doDeleteEntry(client, parentDir, dirName, false, false); err != nil {
|
||||||
|
glog.V(4).Infof("directory %s has %d deletion but still not empty: %v", dir, deletionCount, err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user