[dm-devel] Re: trimmable dm-snapshot?
Douglas McClendon
dmc.fedora at filteredperception.org
Thu Oct 22 21:35:38 UTC 2009
Mike Snitzer wrote:
> On Wed, Oct 21 2009 at 11:05pm -0400,
> Douglas McClendon <dmc.fedora at filteredperception.org> wrote:
>
>> Has anyone looked into the idea of dm-snapshots responding
>> appropriately to trims from filesystems?
>>
>> I.e. the efficiency problem of a dm-snapshotted ext filesystem
>> having files created and then deleted? I.e. in such a scenario,
>> resources in the cow device end up taken that could be freed if the
>> dm layer could efficiently respond to trim notifications by
>> discarding any useless exceptions?
>>
>> I've been poking around pondering whether an offline quick hack
>> might be possible with libext2fs and enough knowledge of the on-disk
>> persistent snapshot format. I.e. just walk the exception chunks in
>> the cow device, use libext2fs (sufficient? easiest way?) to
>> determine whether all the fsblocks/sectors the chunk contains are
>> all currently unneeded, and if so reclaiming that space (possibly by
>> relocating the last exception. I'm still a distance from truly
>> grokking the on-disk format along with the rest of the dm-snapshot
>> and exception-store code).
>>
>> Does any of this make sense? Been looked at? Seem like a
>> reasonable avenue to pursue?
>
> The snapshot must faithfully maintain a copy of the origin's data
> relative to a particular point in time. You can't use changes to the
> origin (trim or any other change) to delete the exceptions that a
> snapshot is already maintaining. That would invalidate the whole intent
> of the snapshot.
I wasn't asking about trimmable dm-snapshot-origin devices, only
trimmable[1] dm-snapshot devices.
Thinking about snapshot-origin devices, what you say is a valid reason
why such optimization is not remotely easy (or feasible at all).
But for snapshot devices, I think the optimization should be as simple
and effective as I described it. (until I discover some other aspect of
dm that changes my understanding of things).
[1] http://lwn.net/Articles/293658/
-dmc
More information about the dm-devel
mailing list