Решение
aws s3 mb s3://[new-bucket]
aws s3 sync s3://[old-bucket] s3://[new-bucket]
aws s3 rb --force s3://[old-bucket]
объяснение
Для S3 нет функциональности переименования сегментов, потому что в S3 нет никаких технических папок, поэтому мы должны обрабатывать каждый файл внутри сегмента.
Приведенный выше код: 1. создаст новое ведро, 2. скопирует файлы и 3. удалит старое ведро. Вот и все.
Если у вас есть много файлов в вашем ведре, и вы беспокоитесь о затратах, то читайте дальше. За кулисами происходит то, что все файлы внутри корзины сначала копируются, а затем удаляются. Это должно стоить незначительную сумму, если у вас есть несколько тысяч файлов. В противном случае проверьте этот ответ, чтобы увидеть, как это повлияет на вас.
пример
В следующем примере мы создаем и заполняем старое ведро, а затем синхронизируем файлы с новым. Проверьте вывод команд, чтобы увидеть, что делает AWS.
> # bucket suffix so we keep it unique
> suffix="ieXiy2" # used `pwgen -1 -6` to get this
>
> # populate old bucket
> echo "asdf" > asdf.txt
> echo "yxcv" > yxcv.txt
> aws s3 mb s3://old-bucket-$suffix
make_bucket: old-bucket-ieXiy2
> aws s3 cp asdf.txt s3://old-bucket-$suffix/asdf.txt
upload: ./asdf.txt to s3://old-bucket-ieXiy2/asdf.txt
> aws s3 cp yxcv.txt s3://old-bucket-$suffix/yxcv.txt
upload: ./yxcv.txt to s3://old-bucket-ieXiy2/yxcv.txt
>
> # "rename" to new bucket
> aws s3 mb s3://new-bucket-$suffix
make_bucket: new-bucket-ieXiy2
> aws s3 sync s3://old-bucket-$suffix s3://new-bucket-$suffix
copy: s3://old-bucket-ieXiy2/yxcv.txt to s3://new-bucket-ieXiy2/yxcv.txt
copy: s3://old-bucket-ieXiy2/asdf.txt to s3://new-bucket-ieXiy2/asdf.txt
> aws s3 rb --force s3://old-bucket-$suffix
delete: s3://old-bucket-ieXiy2/asdf.txt
delete: s3://old-bucket-ieXiy2/yxcv.txt
remove_bucket: old-bucket-ieXiy2