Wear leveling techniques in flash-based SSDs aim at distributing the erase cycles as uniformly as possible across the memory blocks within the SSD in order to extend its life span. The downside of any wear leveling technique is that it causes additional internal write operations, thereby increasing the so-called write amplification factor, which equals the ratio between the total number of writes performed and the number of writes requested by the host system.
In this paper we address the question whether near-perfect wear leveling is possible at low costs in terms of the write amplification factor. We answer this question affirmatively by presenting a simple randomized algorithm that combines wear leveling with garbage collection. This algorithm guarantees that the wear is nearly perfectly balanced at all times, while causing a low increase in the write amplification. This is demonstrated mathematically using a mean field model in case of uniform random writes and using trace-driven simulation experiments for general workloads.