Abstract
Achieving predictable performance in shared cloud storage services is hard. Tenants want reservations in terms of system-wide application-level throughput, but the provider must ultimately deal with low-level IO resources at each storage node where contention arises. Such a guarantee has thus proven elusive, due to the complexities inherent to modern storage stacks: non-uniform IO amplification, unpredictable IO interference, and non-linear IO performance. This paper presents Libra, a local IO scheduling framework designed for a shared SSD-backed key-value storage system. Libra guarantees per-tenant application-request throughput while achieving high utilization. To accomplish this, Libra leverages two techniques. First, Libra tracks the IO resource consumption of a tenant's application-level requests across complex storage stack interactions, down to low-level IO operations. This allows Libra to allocate per-tenant IO resources for achieving app-request reservations based on their dynamic IO usage profile. Second, Libra uses a disk-IO cost model based on virtual IO operations (VOP) that captures the non-linear relationship between SSD IO bandwidth and IO operation (IOP) throughput. Using VOPs, Libra can both account for the true cost of an IOP and determine the amount of provisionable IO resources available under IO interference. An evaluation shows that Libra, when applied to a LevelDB-based prototype with SSD-backed storage, satisfies tenant app-request reservations and achieves accurate low-level VOP allocations over a range of workloads, while still supporting high utilization.
Original language | English (US) |
---|---|
DOIs | |
State | Published - 2014 |
Event | 9th ACM European Conference on Computer Systems, EuroSys 2014 - Amsterdam, Netherlands Duration: Apr 14 2014 → Apr 16 2014 |
Other
Other | 9th ACM European Conference on Computer Systems, EuroSys 2014 |
---|---|
Country/Territory | Netherlands |
City | Amsterdam |
Period | 4/14/14 → 4/16/14 |
All Science Journal Classification (ASJC) codes
- Hardware and Architecture
- Control and Systems Engineering