mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2024-01-19 02:48:24 +00:00
avoid creating the same bucket with a different randomized name
related to https://github.com/chrislusf/seaweedfs/issues/2492
This commit is contained in:
parent
42d97a3442
commit
c146c76d10
|
@ -86,12 +86,26 @@ func (option *RemoteGatewayOptions) makeBucketedEventProcessor(filerSource *sour
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if *option.createBucketRandomSuffix {
|
|
||||||
// https://docs.aws.amazon.com/AmazonS3/latest/userguide/bucketnamingrules.html
|
bucketPath := util.FullPath(option.bucketsDir).Child(entry.Name)
|
||||||
if len(bucketName)+5 > 63 {
|
remoteLocation, found := option.mappings.Mappings[string(bucketPath)]
|
||||||
bucketName = bucketName[:58]
|
if !found {
|
||||||
|
if *option.createBucketRandomSuffix {
|
||||||
|
// https://docs.aws.amazon.com/AmazonS3/latest/userguide/bucketnamingrules.html
|
||||||
|
if len(bucketName)+5 > 63 {
|
||||||
|
bucketName = bucketName[:58]
|
||||||
|
}
|
||||||
|
bucketName = fmt.Sprintf("%s-%04d", bucketName, rand.Uint32()%10000)
|
||||||
}
|
}
|
||||||
bucketName = fmt.Sprintf("%s-%04d", bucketName, rand.Uint32()%10000)
|
remoteLocation = &remote_pb.RemoteStorageLocation{
|
||||||
|
Name: *option.createBucketAt,
|
||||||
|
Bucket: bucketName,
|
||||||
|
Path: "/",
|
||||||
|
}
|
||||||
|
// need to add new mapping here before getting updates from metadata tailing
|
||||||
|
option.mappings.Mappings[string(bucketPath)] = remoteLocation
|
||||||
|
} else {
|
||||||
|
bucketName = remoteLocation.Bucket
|
||||||
}
|
}
|
||||||
|
|
||||||
glog.V(0).Infof("create bucket %s", bucketName)
|
glog.V(0).Infof("create bucket %s", bucketName)
|
||||||
|
@ -99,16 +113,6 @@ func (option *RemoteGatewayOptions) makeBucketedEventProcessor(filerSource *sour
|
||||||
return fmt.Errorf("create bucket %s in %s: %v", bucketName, remoteConf.Name, err)
|
return fmt.Errorf("create bucket %s in %s: %v", bucketName, remoteConf.Name, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
bucketPath := util.FullPath(option.bucketsDir).Child(entry.Name)
|
|
||||||
remoteLocation := &remote_pb.RemoteStorageLocation{
|
|
||||||
Name: *option.createBucketAt,
|
|
||||||
Bucket: bucketName,
|
|
||||||
Path: "/",
|
|
||||||
}
|
|
||||||
|
|
||||||
// need to add new mapping here before getting upates from metadata tailing
|
|
||||||
option.mappings.Mappings[string(bucketPath)] = remoteLocation
|
|
||||||
|
|
||||||
return filer.InsertMountMapping(option, string(bucketPath), remoteLocation)
|
return filer.InsertMountMapping(option, string(bucketPath), remoteLocation)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue