-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
dm-era is a target that behaves similar to the linear target. In addition it keeps track of which blocks were written within a user defined period of time called an 'era'. Each era target instance maintains the current era as a monotonically increasing 32-bit counter. Use cases include tracking changed blocks for backup software, and partially invalidating the contents of a cache to restore cache coherency after rolling back a vendor snapshot. dm-era is primarily expected to be paired with the dm-cache target. Signed-off-by: Joe Thornber <ejt@redhat.com> Signed-off-by: Mike Snitzer <snitzer@redhat.com>
- Loading branch information
Joe Thornber
authored and
Mike Snitzer
committed
Mar 27, 2014
1 parent
b098d67
commit eec4057
Showing
4 changed files
with
1,851 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,108 @@ | ||
Introduction | ||
============ | ||
|
||
dm-era is a target that behaves similar to the linear target. In | ||
addition it keeps track of which blocks were written within a user | ||
defined period of time called an 'era'. Each era target instance | ||
maintains the current era as a monotonically increasing 32-bit | ||
counter. | ||
|
||
Use cases include tracking changed blocks for backup software, and | ||
partially invalidating the contents of a cache to restore cache | ||
coherency after rolling back a vendor snapshot. | ||
|
||
Constructor | ||
=========== | ||
|
||
era <metadata dev> <origin dev> <block size> | ||
|
||
metadata dev : fast device holding the persistent metadata | ||
origin dev : device holding data blocks that may change | ||
block size : block size of origin data device, granularity that is | ||
tracked by the target | ||
|
||
Messages | ||
======== | ||
|
||
None of the dm messages take any arguments. | ||
|
||
checkpoint | ||
---------- | ||
|
||
Possibly move to a new era. You shouldn't assume the era has | ||
incremented. After sending this message, you should check the | ||
current era via the status line. | ||
|
||
take_metadata_snap | ||
------------------ | ||
|
||
Create a clone of the metadata, to allow a userland process to read it. | ||
|
||
drop_metadata_snap | ||
------------------ | ||
|
||
Drop the metadata snapshot. | ||
|
||
Status | ||
====== | ||
|
||
<metadata block size> <#used metadata blocks>/<#total metadata blocks> | ||
<current era> <held metadata root | '-'> | ||
|
||
metadata block size : Fixed block size for each metadata block in | ||
sectors | ||
#used metadata blocks : Number of metadata blocks used | ||
#total metadata blocks : Total number of metadata blocks | ||
current era : The current era | ||
held metadata root : The location, in blocks, of the metadata root | ||
that has been 'held' for userspace read | ||
access. '-' indicates there is no held root | ||
|
||
Detailed use case | ||
================= | ||
|
||
The scenario of invalidating a cache when rolling back a vendor | ||
snapshot was the primary use case when developing this target: | ||
|
||
Taking a vendor snapshot | ||
------------------------ | ||
|
||
- Send a checkpoint message to the era target | ||
- Make a note of the current era in its status line | ||
- Take vendor snapshot (the era and snapshot should be forever | ||
associated now). | ||
|
||
Rolling back to an vendor snapshot | ||
---------------------------------- | ||
|
||
- Cache enters passthrough mode (see: dm-cache's docs in cache.txt) | ||
- Rollback vendor storage | ||
- Take metadata snapshot | ||
- Ascertain which blocks have been written since the snapshot was taken | ||
by checking each block's era | ||
- Invalidate those blocks in the caching software | ||
- Cache returns to writeback/writethrough mode | ||
|
||
Memory usage | ||
============ | ||
|
||
The target uses a bitset to record writes in the current era. It also | ||
has a spare bitset ready for switching over to a new era. Other than | ||
that it uses a few 4k blocks for updating metadata. | ||
|
||
(4 * nr_blocks) bytes + buffers | ||
|
||
Resilience | ||
========== | ||
|
||
Metadata is updated on disk before a write to a previously unwritten | ||
block is performed. As such dm-era should not be effected by a hard | ||
crash such as power failure. | ||
|
||
Userland tools | ||
============== | ||
|
||
Userland tools are found in the increasingly poorly named | ||
thin-provisioning-tools project: | ||
|
||
https://github.com/jthornber/thin-provisioning-tools |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.