2013-06-27 11:40:08 +01:00
|
|
|
Introduction
|
|
|
|
============
|
2011-09-09 12:08:10 +01:00
|
|
|
|
2013-06-27 11:40:08 +01:00
|
|
|
A suite of tools for manipulating the metadata of the dm-thin
|
|
|
|
device-mapper target.
|
|
|
|
|
|
|
|
Requirements
|
|
|
|
============
|
|
|
|
|
|
|
|
A C++ compiler that supports the c++11 standard (eg, g++).
|
|
|
|
The [Boost C++ library](http://www.boost.org/).
|
|
|
|
The [expat](http://expat.sourceforge.net/) xml parser library (version 1).
|
2014-08-06 16:29:50 +01:00
|
|
|
The libaio library (note this is not the same as the aio library that you get by linking -lrt)
|
2013-06-27 11:40:08 +01:00
|
|
|
make, autoconf etc.
|
|
|
|
|
|
|
|
There are more requirements for testing, detailed below.
|
|
|
|
|
|
|
|
Building
|
|
|
|
========
|
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
./configure
|
|
|
|
make
|
|
|
|
sudo make install
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
Quick examples
|
|
|
|
==============
|
|
|
|
|
|
|
|
These tools introduce an xml format for the metadata. This is useful
|
|
|
|
for making backups, or allowing scripting languages to generate or
|
|
|
|
manipulate metadata. A Ruby library for this available;
|
|
|
|
[thinp_xml](https://rubygems.org/gems/thinp_xml).
|
|
|
|
|
|
|
|
To convert the binary metadata format that the kernel uses to this xml
|
|
|
|
format use _thin\_dump_.
|
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
thin_dump --format xml /dev/mapper/my_thinp_metadata
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
To convert xml back to the binary form use _thin\_restore_.
|
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
thin_restore -i my_xml -o /dev/mapper/my_thinp_metadata
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
You should periodically check the health of your metadata, much as you
|
|
|
|
fsck a filesystem. Your volume manager (eg, LVM2) should be doing
|
|
|
|
this for you behind the scenes.
|
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
thin_check /dev/mapper/my_thinp_metadata
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
Checking all the mappings can take some time, you can omit this part
|
|
|
|
of the check if you wish.
|
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
thin_check --skip-mappings /dev/mapper/my_thinp_metadata
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
If your metadata has become corrupt for some reason (device failure,
|
|
|
|
user error, kernel bug), thin_check will tell you what the effects of
|
|
|
|
the corruption are (eg, which thin devices are effected, which
|
|
|
|
mappings).
|
|
|
|
|
|
|
|
There are two ways to repair metadata. The simplest is via the
|
|
|
|
_thin\_repair_ tool.
|
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
thin_repair -i /dev/mapper/broken_metadata_dev -o /dev/mapper/new_metadata_dev
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
This is a non-destructive operation that writes corrected metadata to
|
|
|
|
a new metadata device.
|
|
|
|
|
|
|
|
Alternatively you can go via the xml format (perhaps you want to
|
|
|
|
inspect the repaired metadata before restoring).
|
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
thin_dump --repair /dev/mapper/my_metadata > repaired.xml
|
|
|
|
thinp_restore -i repaired.xml -o /dev/mapper/my_metadata
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
Development
|
|
|
|
===========
|
|
|
|
|
|
|
|
Autoconf
|
|
|
|
--------
|
|
|
|
|
|
|
|
If you've got the source from github you'll need to create the
|
2013-06-27 11:55:57 +01:00
|
|
|
configure script with autoconf. I do this by running:
|
2013-06-27 11:40:08 +01:00
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
autoreconf
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
Enable tests
|
|
|
|
------------
|
|
|
|
|
|
|
|
You will need to enable tests when you configure.
|
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
./configure --enable-testing
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
Unit tests
|
|
|
|
----------
|
|
|
|
|
|
|
|
Unit tests are implemented using the google mock framework. This is a
|
|
|
|
source library that you will have to download. A script is provided
|
|
|
|
to do this for you.
|
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
./get-gmock.sh
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
All tests can be run via:
|
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
make unit-test
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
Alternatively you may want to run a subset of the tests:
|
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
make unit-tests/unit_tests
|
|
|
|
unit-tests/unit_tests --gtest_filter=BtreeTests.*
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
Functional tests
|
|
|
|
----------------
|
|
|
|
|
|
|
|
These top level tests are implemented using the
|
|
|
|
[cucumber](http://cukes.info/) tool. They check the user interface of
|
|
|
|
the tools (eg, command line switches are accepted and effective).
|
|
|
|
|
|
|
|
I've provided a Gemfile, so installing this should be easy:
|
|
|
|
|
2013-06-27 11:57:10 +01:00
|
|
|
- Install Ruby 1.9.x. I recommend doing this via RVM.
|
|
|
|
- Make sure _bundler_ is installed:
|
2013-06-27 11:40:08 +01:00
|
|
|
|
2013-06-27 11:57:57 +01:00
|
|
|
gem install bundler
|
2013-06-27 11:40:08 +01:00
|
|
|
|
2013-06-27 11:57:10 +01:00
|
|
|
- Install dependencies (including _cucumber_ and _thinp\_xml_)
|
2013-06-27 11:40:08 +01:00
|
|
|
|
2013-06-27 11:57:57 +01:00
|
|
|
bundle
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
Once you've done this you can run the tests with a simple:
|
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
cucumber
|
2013-06-27 11:40:08 +01:00
|
|
|
|
|
|
|
Or specific tests with:
|
|
|
|
|
2013-06-27 11:55:57 +01:00
|
|
|
cucumber features/thin_restore -n 'print help'
|
2016-03-04 18:18:29 +03:00
|
|
|
|
|
|
|
|
|
|
|
Dump Metadata
|
|
|
|
=============
|
|
|
|
|
|
|
|
To dump the metadata of a live thin pool, you must first create a snapshot of
|
|
|
|
the metadata:
|
|
|
|
|
|
|
|
$ dmsetup message vg001-mythinpool-tpool 0 reserve_metadata_snap
|
|
|
|
|
|
|
|
Extract the metadata:
|
|
|
|
|
2016-03-04 18:30:02 +03:00
|
|
|
$ sudo bin/thin_dump -m /dev/mapper/vg001-mythinpool_tmeta
|
2016-03-04 18:18:29 +03:00
|
|
|
<superblock uuid="" time="1" transaction="2" data_block_size="128"nr_data_blocks="0">
|
|
|
|
<device dev_id="1" mapped_blocks="1" transaction="0" creation_time="0" snap_time="1">
|
|
|
|
<single_mapping origin_block="0" data_block="0" time="0"/>
|
|
|
|
</device>
|
|
|
|
<device dev_id="2" mapped_blocks="1" transaction="1" creation_time="1" snap_time="1">
|
|
|
|
<single_mapping origin_block="0" data_block="0" time="0"/>
|
|
|
|
</device>
|
|
|
|
</superblock>
|
|
|
|
|
|
|
|
Finally, release the root:
|
|
|
|
|
|
|
|
$ dmsetup message vg001-mythinpool-tpool 0 release_metadata_snap
|