The authors analyze some SSD behaviors and provide insights into some "unwritten contracts" clients of SSDs should follow for high performance.
- Introduction
- Background
- Unwritten Contract
- Request Scale
- Locality
- Aligned Sequentiality
- Grouping by Death Time
- Uniform Data Lifetime
- Discussion
- Methodology
- The Contractors
- Request Scale
- Locality
- Aligned Sequentiality
- Grouping by Death Time
- Uniform Data Lifetime
- Discussion
- Related Work
- Conclusions
The SSD performance is improving and thus the storage stack is shifting from the HDD era to the SSD era. However, if we misuse SSDs, performance degradation & fluctuation and early end of device life will occur. The authors look into the right way to achieve high performance with SSDs. For HDDs, the unwritten contracts include:
- Sequential accesses are best
- Nearby accesses are more efficient than farther ones
In this work, the authors present five rules for SSDs.
Clients should issue large requests or multiple concurrent, outstanding small requests to get more throughput and benefit from the internal parallelism (multiple channels) of SSDs. A small request scale leads to low resource utilization. On violation, the low internal parallelism leads to 18x less read bandwidth and 10x less write bandwidth.
Clients should access with locality (temporal and/or spatial). Possible benefits include reduced translation cache misses, reduced translation cache reads/writes, reduced data cache misses, and reduced write-amp from flash garbage collection. On violation, the performance impact is 2.2x average response time.
Clients should start writing at the aligned beginning of a block boundary and write files sequentially using large write requests. For an FTL that can do hybrid block mapping, this requires fewer entries in the translation table. In hybrid FTLs, there are both page-level mapping and block-level mapping. Page-level is flexible but takes more space, and block-level is less flexible but takes less space.
To prevent garbage collection (and thus data movement), all data in an erase block should be discarded at the same time. On violation, the performance penalty and write amplification leads to 4.8x less write bandwidth, 1.6x less throughput, and 1.8x less block erasure count.
Clients of SSDs should create data with similar lifetimes. Uneven lifetime leads to uneven wearout, and FTLs may perform wear-leveling which incurs data movements. On violation, the performance penalty and write amplification leads to 1.6x less write latency.
WiscSim, the first SSD simulator that supports NCQ, and WiscSee, a discrete-event SSD simulator, are used to study and understand system performance for every FS/app pair. Applications studied include LevelDB, RocksDB, SQLite (rollback + write-ahead-logging mode), and the Varmail benchmark. File systems studied include ext4, XFS, and F2FS (designed for SSDs).
The following are observed:
- Log structure increases the scale of write size for applications, as expected.
- The scale of read requests is often low.
- SSD-conscious optimizations have room for improvements.
- Frequent data barriers in applications limit request scale.
- Linux buffered I/O implementation limits request scale.
- Frequent data barriers in file systems limit request scale.
- File system log structuring fragments application data structures.
- Delaying and merging slow non-data operations could boost immediate performance.
- SSDs demand aggressive and accurate prefetching.
- Aggressively reusing space improves locality.
- Legacy policies could break locality.
- Log structuring is not always log-structured.
- Log structuring can spread data widely across a device and thus reduce locality.
- Application log structuring does not guarantee alignment.
- Log-structured file systems may not be as sequential as commonly expected.
- Sequential + sequential 6= sequential.
- Application log structuring does not reduce garbage collection.
- Applications often separate data of different death time and file systems mix them.
- All file systems typically have shorter tails with segmented FTLs than they have with non-segmented FTLs, suggesting that FTLs should always be segmented.
- All file systems fail to group data from different directories to prevent them from being mixed in the SSD.
- F2FS sacrifices too much sustainable performance for immediate performance.
- Application and file system data lifetimes differ significantly.
- All file systems have allocation biases.
- In-place-update file systems preserve data lifetime of applications.
- Being friendly to one rule is not enough: the SSD contract is multi-dimensional.
- Although not perfect, traditional file systems still perform well upon SSDs.
- The complex interactions between applications, file systems, and FTLs demand tooling for analysis.
- Myths spread if the unwritten contract is not clarified.
- FTL: Flash Translation Layer
{% file src="../../.gitbook/assets/ContractSSDs (1).pptx" %} Prof. Andrea's course slides on this work {% endfile %}