DEV Community

k.goto for AWS Community Builders

Posted on • Updated on

Tool for fast deletion and emptying of S3 buckets (versioning supported)

I have released an OSS tool that solves the following problems.

  • The button to empty an S3 bucket is present in the S3 console but not in the CLI or SDK.
    • If versioning is off, it can be done with aws s3 rm --recursive in CLI, but it's slow.
    • If versioning is on, it can't be done in the first place.
  • When deleting an S3 bucket, the bucket must be empty to be deleted.
    • It can be done with aws s3 rb --force in CLI, but it's slow.
  • You want to empty it, but can't delete + re-create the bucket with CDK's autoDeleteObjects, etc. because it is dependent on other resources.
  • You have to wait a day to try to delete it with S3's lifecycle function.

You can now empty or delete entire buckets very easily and fast.

Moreover, you can do multiple buckets at once, and also search buckets interactively!


What is

The CLI tool "cls3" is to CLear Amazon S3 Buckets(AWS).

It empties (so deletes all objects and versions/delete-markers in) S3 Buckets or deletes the buckets themselves.

This tool allows you to search for bucket names and delete or empty multiple buckets.


Source Code

Implemented in Go language. Please see GitHub.


Features

Bucket deletion option

Initially, the tool was intended to "empty the bucket", but since I was going to go through the trouble, I also added an option (-f|--force) to "delete the bucket as well".

Search for bucket names and delete multiple buckets

As described below, you can search for bucket names and delete or empty multiple buckets at once.

Cross-region

In deleting multiple buckets, you can delete them all at once, even if they are in multiple regions.

Versioning

Even if versioning is turned on, you can empty it just as if it were turned off. Therefore, you can use it without being aware of the versioning settings.

Deletion of old version objects only

The -o | --oldVersionsOnly option allows you to delete only old versions and all delete-markers without new versions and a bucket itself.

So you can retain the latest version objects only.

This option cannot be specified with the -f | --force option.

Number of objects that can be deleted

The delete-objects API provided by the CLI and SDK has a limit of "the number of objects that can be deleted in one command is limited to 1000", but This tool has no limit on the number.

Parallel Processing

When there are more than 1000 object versions, object deletion is performed in Parallel Processing.

As mentioned above, up to 1,000 objects can be deleted at once using the SDK's 1 API, so each unit is executed in parallel.

Therefore, it is quite fast.

As a test, I prepared two buckets with the same 10,000 objects (very small in size) and tried deleting them with the "Empty" button on the console and the tool I created (local environment/logical CPU core count 8) respectively, and it took 22 seconds on the console and 8 seconds with this tool. That is 3 times faster than the console.

Also, with 10 million objects (including version and delete markers), the deletion was completed in about 100 minutes. (This depends on the operating environment, so I can't make any guarantees.)

Retry on 503 error

When there are tens of thousands of objects, a SlowDown error (503 error) may occur on the S3 api side in rare cases when deleting them all at once using the CLI or SDK.

When this occurs, cls3 responds by adding a mechanism that waits a few seconds and retries automatically several times.

Progress bar

A progress bar will appear by default. This gives you the following information

  • Number of all objects
  • Number of objects deleted
  • Estimated completion time
❯ cls3 -i
Filter a keyword of bucket names: testgoto

? Select buckets.
 testgoto1
OK? (Y/n)

INF testgoto1 Checking...
INF testgoto1 Clearing...
  52% |██████████████████████████                        | (12000/22882) [4s:4s]
Enter fullscreen mode Exit fullscreen mode

-q | --quiet option to hide the progress bar.


Install

Homebrew

brew install go-to-k/tap/cls3
Enter fullscreen mode Exit fullscreen mode

Linux, Darwin (macOS) and Windows

curl -fsSL https://raw.githubusercontent.com/go-to-k/cls3/main/install.sh | sh
cls3 -h

# To install a specific version of cls3
# e.g. version 0.13.2
curl -fsSL https://raw.githubusercontent.com/go-to-k/cls3/main/install.sh | sh -s "v0.13.2"
cls3 -h
Enter fullscreen mode Exit fullscreen mode

aqua

aqua g -i go-to-k/cls3
Enter fullscreen mode Exit fullscreen mode

Binaries

Source build (development version)

The Go environment is required.

git clone https://github.com/go-to-k/cls3.git
cd cls3
make install
Enter fullscreen mode Exit fullscreen mode

How to use

cls3 -b <bucketName> [-b <bucketName>] [-p <profile>] [-r <region>] [-f|--force] [-i|--interactive] [-q|--quiet] [-o|--oldVersionsOnly]
Enter fullscreen mode Exit fullscreen mode

Options

  • -b, --bucketName: optional
    • Bucket name
    • Must be specified in not interactive mode
    • Otherwise (so in the interactive mode), you can not specify this!
    • Multiple specifications are possible.
    • cls3 -b test1 -b test2
  • -p, --profile: optional
    • AWS profile name
  • -r, --region: optional(default: ap-northeast-1)
    • AWS Region
    • It is not necessary to be aware of this as it can be used across regions.
  • -f, --force: optional
    • ForceMode (Delete the bucket together)
  • -i, --interactive: optional
    • Interactive Mode for buckets selection
  • -q, --quiet: optional
    • Not to display a progress bar
  • -o, --oldVersionsOnly: optional
    • Delete old version objects only (including all delete-markers)
    • Do not specify the -f option if you specify this option.

Interactive Mode

BucketName Selection

In the interactive mode(-i option), you can search bucket names and select buckets.

It is designed to be searchable and deletable across regions, so it can be used without being region-aware.

It can be empty.

❯ cls3 -i
Filter a keyword of bucket names: test-goto
Enter fullscreen mode Exit fullscreen mode

Then you select bucket names in the UI.

? Select buckets.
  [Use arrows to move, space to select, <right> to all, <left> to none, type to filter]
> [x]  test-goto-bucket-1
  [ ]  test-goto-bucket-2
  [x]  test-goto-bucket-3
Enter fullscreen mode Exit fullscreen mode

Finally

I created a CLI tool for fast deletion and emptying of S3 buckets.

You can use it if you like!

Top comments (5)

Collapse
 
mmuller88 profile image
Martin Muller

Nice. Thank you so much :)!

Collapse
 
Sloan, the sloth mascot
Comment deleted
Collapse
 
Sloan, the sloth mascot
Comment deleted
 
Sloan, the sloth mascot
Comment deleted
Collapse
 
k_goto profile image
k.goto

@mmuller88
Thank you too! Please use it!