Merge 6a7b88e788
into 25401592e1
This commit is contained in:
commit
fba7fc19c9
1 changed files with 11 additions and 10 deletions
|
@ -5,6 +5,7 @@ import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net/url"
|
"net/url"
|
||||||
|
"sync/atomic"
|
||||||
|
|
||||||
"github.com/golang/glog"
|
"github.com/golang/glog"
|
||||||
"github.com/minio/minio-go/v7"
|
"github.com/minio/minio-go/v7"
|
||||||
|
@ -170,11 +171,11 @@ func (client *s3Client) removeObjects(bucketName, prefix string) error {
|
||||||
// will delete files one by one without file lock
|
// will delete files one by one without file lock
|
||||||
func (client *s3Client) removeObjectsOneByOne(bucketName, prefix string) error {
|
func (client *s3Client) removeObjectsOneByOne(bucketName, prefix string) error {
|
||||||
parallelism := 16
|
parallelism := 16
|
||||||
objectsCh := make(chan minio.ObjectInfo, 1)
|
objectsCh := make(chan minio.ObjectInfo, parallelism)
|
||||||
guardCh := make(chan int, parallelism)
|
guardCh := make(chan int, parallelism)
|
||||||
var listErr error
|
var listErr error
|
||||||
totalObjects := 0
|
var totalObjects int64 = 0
|
||||||
removeErrors := 0
|
var removeErrors int64 = 0
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
defer close(objectsCh)
|
defer close(objectsCh)
|
||||||
|
@ -185,7 +186,7 @@ func (client *s3Client) removeObjectsOneByOne(bucketName, prefix string) error {
|
||||||
listErr = object.Err
|
listErr = object.Err
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
totalObjects++
|
atomic.AddInt64(&totalObjects, 1)
|
||||||
objectsCh <- object
|
objectsCh <- object
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
@ -197,15 +198,15 @@ func (client *s3Client) removeObjectsOneByOne(bucketName, prefix string) error {
|
||||||
|
|
||||||
for object := range objectsCh {
|
for object := range objectsCh {
|
||||||
guardCh <- 1
|
guardCh <- 1
|
||||||
go func() {
|
go func(obj minio.ObjectInfo) {
|
||||||
err := client.minio.RemoveObject(client.ctx, bucketName, object.Key,
|
err := client.minio.RemoveObject(client.ctx, bucketName, obj.Key,
|
||||||
minio.RemoveObjectOptions{VersionID: object.VersionID})
|
minio.RemoveObjectOptions{VersionID: obj.VersionID})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
glog.Errorf("Failed to remove object %s, error: %s", object.Key, err)
|
glog.Errorf("Failed to remove object %s, error: %s", obj.Key, err)
|
||||||
removeErrors++
|
atomic.AddInt64(&removeErrors, 1)
|
||||||
}
|
}
|
||||||
<- guardCh
|
<- guardCh
|
||||||
}()
|
}(object)
|
||||||
}
|
}
|
||||||
for i := 0; i < parallelism; i++ {
|
for i := 0; i < parallelism; i++ {
|
||||||
guardCh <- 1
|
guardCh <- 1
|
||||||
|
|
Loading…
Add table
Reference in a new issue