AWS Elastic Block Storage (EBS) – Can We Get It Truly Elastic?Peter Zaitsev
AWS Elastic Block Storage (EBS) is great and it’s got better through the years, adding different storage types and features like Provisioned IOPS. However, it still has the most basic inconvenient requirement – I have to decide in advance how much space I need to allocate, and pay for all of that allocated space whether I use it or not.
It would be so much better if AWS would allow true consumption model pricing with EBS, where you pay for the storage used, not the storage allocated. This is already the case for S3, RDS, and even EC2 instances (with Unlimited Option on T2/T3 Instances), not to mention Serverless focused services.
For example, I would love to be able to create a 1TB EBS volume but only pay for 10GB of storage if I only use this amount of space.
Modern storage subsystems do a good job differentiating between the space available on the block device and what’s being used by user files and filesystem metadata. The space that’s not allocated any more can be TRIMmed. This is a basic requirement for working well on flash storage, and as modern EC2 instances already provision EBS storage as emulated NVMe devices, I would imagine Amazon could hook into such functionality to track space actually used.
For us at Percona this would make shipping applications on AWS Marketplace much more convenient. Right now for Percona Monitoring and Management (PMM) we have to choose how much space to allocate to the EBS volume by default, picking between it being expensive to run because of paying for the large unused EBS volume or setting a very limited by default capacity that needs user action to resize the EBS volume. Consumption-based EBS pricing would solve this dilemma.
This problem seems to be well recognized and understood. For example Pure Storage Cloud Block Storage (currently in Beta) is expected to have such a feature.
I hope with its insane customer focus AWS will add this feature in the future, but currently we have to get by without it.