2008-10-08 16:50:13 +04:00
.TH LVCONVERT 8 "LVM TOOLS #VERSION#" "Red Hat, Inc" \" -*- nroff -*-
2006-08-19 01:49:19 +04:00
.SH NAME
2007-01-10 17:13:46 +03:00
lvconvert \- convert a logical volume from linear to mirror or snapshot
2006-08-19 01:49:19 +04:00
.SH SYNOPSIS
.B lvconvert
2010-03-27 01:15:43 +03:00
\- m|\- \- mirrors Mirrors [\- \- mirrorlog {disk|core|mirrored}] [\- \- corelog] [\- R|\- \- regionsize MirrorLogRegionSize]
2008-11-12 18:01:35 +03:00
[\- A|\- \- alloc AllocationPolicy]
2009-06-30 22:39:31 +04:00
[\- b|\- \- background] [\- f|\- \- force] [\- i|\- \- interval Seconds]
2008-11-12 18:01:35 +03:00
[\- h|\- ?|\- \- help]
2010-04-13 05:54:32 +04:00
[\- \- stripes Stripes [\- I|\- \- stripesize StripeSize]]
2009-08-04 12:09:52 +04:00
[\- \- noudevsync]
2009-06-30 22:39:31 +04:00
[\- v|\- \- verbose] [\- y|\- \- yes]
2006-08-19 01:49:19 +04:00
[\- \- version]
2009-08-10 21:23:04 +04:00
.br
LogicalVolume[Path] [PhysicalVolume[Path][:PE[-PE]]...]
2007-01-10 17:13:46 +03:00
.br
This patch adds the capability to split off a mirror legs.
It is pretty much the same as reducing the number of
mirror legs, but we just don't delete them afterwards.
The following command line interface is enforced:
prompt> lvconvert --splitmirror <n> -n <name> <VG>/<LV>
where 'n' is the number of images to split off, and
where 'name' is the name of the newly split off logical volume.
If more than one leg is split off, a new mirror will be the
result. The newly split off mirror will have a 'core' log.
Example:
[root@bp-01 LVM2]# !lvs
lvs -a -o name,copy_percent,devices
LV Copy% Devices
lv 100.00 lv_mimage_0(0),lv_mimage_1(0),lv_mimage_2(0),lv_mimage_3(0)
[lv_mimage_0] /dev/sdb1(0)
[lv_mimage_1] /dev/sdc1(0)
[lv_mimage_2] /dev/sdd1(0)
[lv_mimage_3] /dev/sde1(0)
[lv_mlog] /dev/sdi1(0)
[root@bp-01 LVM2]# lvconvert --splitmirrors 2 --name split vg/lv /dev/sd[ce]1
Logical volume lv converted.
[root@bp-01 LVM2]# !lvs
lvs -a -o name,copy_percent,devices
LV Copy% Devices
lv 100.00 lv_mimage_0(0),lv_mimage_2(0)
[lv_mimage_0] /dev/sdb1(0)
[lv_mimage_2] /dev/sdd1(0)
[lv_mlog] /dev/sdi1(0)
split 100.00 split_mimage_0(0),split_mimage_1(0)
[split_mimage_0] /dev/sde1(0)
[split_mimage_1] /dev/sdc1(0)
It can be seen that '--splitmirror <n>' is exactly the same
as '--mirrors -<n>' (note the minus sign), except there is the
additional notion to keep the image being detached from the
mirror instead of just throwing it away.
Signed-off-by: Jonathan Brassow <jbrassow@redhat.com>
2010-01-09 01:00:31 +03:00
.br
.B lvconvert
\- \- splitmirrors Images \- \- name SplitLogicalVolumeName
.br
MirrorLogicalVolume[Path] [SplittablePhysicalVolume[Path][:PE[-PE]]...]
.br
2007-01-10 17:13:46 +03:00
.br
.B lvconvert
2008-11-12 18:01:35 +03:00
\- s|\- \- snapshot [\- c|\- \- chunksize ChunkSize]
[\- h|\- ?|\- \- help]
2009-08-04 12:09:52 +04:00
[\- \- noudevsync]
2008-11-12 18:01:35 +03:00
[\- v|\- \- verbose]
[\- Z|\- \- zero y|n]
2007-01-10 17:13:46 +03:00
[\- \- version]
.br
OriginalLogicalVolume[Path] SnapshotLogicalVolume[Path]
2010-01-13 04:55:05 +03:00
.br
2009-08-03 01:01:51 +04:00
2010-01-13 04:55:05 +03:00
.br
.B lvconvert
\- \- merge [\- b|\- \- background] [\- i|\- \- interval Seconds]
[\- h|\- ?|\- \- help]
[\- v|\- \- verbose]
[\- \- version]
2010-02-06 01:44:37 +03:00
SnapshotLogicalVolume[Path]...
2010-01-13 04:55:05 +03:00
.br
.br
2009-08-03 01:01:51 +04:00
.B lvconvert
\- \- repair
[\- h|\- ?|\- \- help]
[\- v|\- \- verbose]
[\- \- version]
LogicalVolume[Path] [PhysicalVolume[Path]...]
2006-08-19 01:49:19 +04:00
.SH DESCRIPTION
lvconvert will change a linear logical volume to a mirror
2007-01-10 17:13:46 +03:00
logical volume or to a snapshot of linear volume and vice versa.
It is also used to add and remove disk logs from mirror devices.
2009-10-26 16:41:13 +03:00
.br
If the conversion requires allocation of physical extents (for
example, when converting from linear to mirror) and you specify
one or more PhysicalVolumes (optionally with ranges of physical
extents), allocation of physical extents will be restricted to
these physical extents. If the conversion frees physical extents
(for example, when converting from a mirror to a linear, or reducing
mirror legs) and you specify one or more PhysicalVolumes,
the freed extents come first from the specified PhysicalVolumes.
2006-08-19 01:49:19 +04:00
.SH OPTIONS
See \fB lvm\fP for common options.
2007-01-10 17:13:46 +03:00
.br
2010-01-13 04:55:05 +03:00
Exactly one of \- \- splitmirrors, \- \- mirrors, \- \- repair, \- \- snapshot
or \- \- merge arguments is required.
2007-01-10 17:13:46 +03:00
.br
2006-08-19 01:49:19 +04:00
.TP
.I \- m, \- \- mirrors Mirrors
Specifies the degree of the mirror you wish to create.
For example, "-m 1" would convert the original logical
volume to a mirror volume with 2-sides; that is, a
linear volume plus one copy.
.TP
2010-04-13 20:13:08 +04:00
.I \- \- mirrorlog {disk|core|mirrored}
2007-08-25 01:01:52 +04:00
Specifies the type of log to use.
The default is disk, which is persistent and requires
a small amount of storage space, usually on a separate device
from the data being mirrored.
Core may be useful for short-lived mirrors: It means the mirror is
regenerated by copying the data from the first device again every
time the device is activated - perhaps, for example, after every reboot.
2010-03-27 01:15:43 +03:00
Using "mirrored" will create a persistent log that is itself mirrored.
2007-08-10 00:43:29 +04:00
.TP
.I \- \- corelog
2007-08-30 23:34:19 +04:00
The optional argument "--corelog" is the same as specifying "--mirrorlog core".
2006-10-07 14:47:05 +04:00
.TP
.I \- R, \- \- regionsize MirrorLogRegionSize
A mirror is divided into regions of this size (in MB), and the mirror log
uses this granularity to track which regions are in sync.
2007-12-22 15:13:29 +03:00
.TP
.I \- b, \- \- background
Run the daemon in the background.
.TP
.I \- i, \- \- interval Seconds
Report progress as a percentage at regular intervals.
2007-01-10 17:13:46 +03:00
.br
.TP
2009-08-04 12:09:52 +04:00
.I \- \- noudevsync
Disable udev synchronisation. The
process will not wait for notification from udev.
It will continue irrespective of any possible udev processing
in the background. You should only use this if udev is not running
or has rules that ignore the devices LVM2 creates.
This patch adds the capability to split off a mirror legs.
It is pretty much the same as reducing the number of
mirror legs, but we just don't delete them afterwards.
The following command line interface is enforced:
prompt> lvconvert --splitmirror <n> -n <name> <VG>/<LV>
where 'n' is the number of images to split off, and
where 'name' is the name of the newly split off logical volume.
If more than one leg is split off, a new mirror will be the
result. The newly split off mirror will have a 'core' log.
Example:
[root@bp-01 LVM2]# !lvs
lvs -a -o name,copy_percent,devices
LV Copy% Devices
lv 100.00 lv_mimage_0(0),lv_mimage_1(0),lv_mimage_2(0),lv_mimage_3(0)
[lv_mimage_0] /dev/sdb1(0)
[lv_mimage_1] /dev/sdc1(0)
[lv_mimage_2] /dev/sdd1(0)
[lv_mimage_3] /dev/sde1(0)
[lv_mlog] /dev/sdi1(0)
[root@bp-01 LVM2]# lvconvert --splitmirrors 2 --name split vg/lv /dev/sd[ce]1
Logical volume lv converted.
[root@bp-01 LVM2]# !lvs
lvs -a -o name,copy_percent,devices
LV Copy% Devices
lv 100.00 lv_mimage_0(0),lv_mimage_2(0)
[lv_mimage_0] /dev/sdb1(0)
[lv_mimage_2] /dev/sdd1(0)
[lv_mlog] /dev/sdi1(0)
split 100.00 split_mimage_0(0),split_mimage_1(0)
[split_mimage_0] /dev/sde1(0)
[split_mimage_1] /dev/sdc1(0)
It can be seen that '--splitmirror <n>' is exactly the same
as '--mirrors -<n>' (note the minus sign), except there is the
additional notion to keep the image being detached from the
mirror instead of just throwing it away.
Signed-off-by: Jonathan Brassow <jbrassow@redhat.com>
2010-01-09 01:00:31 +03:00
.br
2009-08-04 12:09:52 +04:00
.TP
This patch adds the capability to split off a mirror legs.
It is pretty much the same as reducing the number of
mirror legs, but we just don't delete them afterwards.
The following command line interface is enforced:
prompt> lvconvert --splitmirror <n> -n <name> <VG>/<LV>
where 'n' is the number of images to split off, and
where 'name' is the name of the newly split off logical volume.
If more than one leg is split off, a new mirror will be the
result. The newly split off mirror will have a 'core' log.
Example:
[root@bp-01 LVM2]# !lvs
lvs -a -o name,copy_percent,devices
LV Copy% Devices
lv 100.00 lv_mimage_0(0),lv_mimage_1(0),lv_mimage_2(0),lv_mimage_3(0)
[lv_mimage_0] /dev/sdb1(0)
[lv_mimage_1] /dev/sdc1(0)
[lv_mimage_2] /dev/sdd1(0)
[lv_mimage_3] /dev/sde1(0)
[lv_mlog] /dev/sdi1(0)
[root@bp-01 LVM2]# lvconvert --splitmirrors 2 --name split vg/lv /dev/sd[ce]1
Logical volume lv converted.
[root@bp-01 LVM2]# !lvs
lvs -a -o name,copy_percent,devices
LV Copy% Devices
lv 100.00 lv_mimage_0(0),lv_mimage_2(0)
[lv_mimage_0] /dev/sdb1(0)
[lv_mimage_2] /dev/sdd1(0)
[lv_mlog] /dev/sdi1(0)
split 100.00 split_mimage_0(0),split_mimage_1(0)
[split_mimage_0] /dev/sde1(0)
[split_mimage_1] /dev/sdc1(0)
It can be seen that '--splitmirror <n>' is exactly the same
as '--mirrors -<n>' (note the minus sign), except there is the
additional notion to keep the image being detached from the
mirror instead of just throwing it away.
Signed-off-by: Jonathan Brassow <jbrassow@redhat.com>
2010-01-09 01:00:31 +03:00
.I \- \- splitmirrors Images
The number of redundant Images of a mirror to be split off and used
to form a new logical volume. A name must be supplied for the
newly-split-off logical volume using the \- \- name argument.
.TP
.I \- n Name
The name to apply to a logical volume which has been split off from
a mirror logical volume.
2009-04-23 20:56:21 +04:00
.br
This patch adds the capability to split off a mirror legs.
It is pretty much the same as reducing the number of
mirror legs, but we just don't delete them afterwards.
The following command line interface is enforced:
prompt> lvconvert --splitmirror <n> -n <name> <VG>/<LV>
where 'n' is the number of images to split off, and
where 'name' is the name of the newly split off logical volume.
If more than one leg is split off, a new mirror will be the
result. The newly split off mirror will have a 'core' log.
Example:
[root@bp-01 LVM2]# !lvs
lvs -a -o name,copy_percent,devices
LV Copy% Devices
lv 100.00 lv_mimage_0(0),lv_mimage_1(0),lv_mimage_2(0),lv_mimage_3(0)
[lv_mimage_0] /dev/sdb1(0)
[lv_mimage_1] /dev/sdc1(0)
[lv_mimage_2] /dev/sdd1(0)
[lv_mimage_3] /dev/sde1(0)
[lv_mlog] /dev/sdi1(0)
[root@bp-01 LVM2]# lvconvert --splitmirrors 2 --name split vg/lv /dev/sd[ce]1
Logical volume lv converted.
[root@bp-01 LVM2]# !lvs
lvs -a -o name,copy_percent,devices
LV Copy% Devices
lv 100.00 lv_mimage_0(0),lv_mimage_2(0)
[lv_mimage_0] /dev/sdb1(0)
[lv_mimage_2] /dev/sdd1(0)
[lv_mlog] /dev/sdi1(0)
split 100.00 split_mimage_0(0),split_mimage_1(0)
[split_mimage_0] /dev/sde1(0)
[split_mimage_1] /dev/sdc1(0)
It can be seen that '--splitmirror <n>' is exactly the same
as '--mirrors -<n>' (note the minus sign), except there is the
additional notion to keep the image being detached from the
mirror instead of just throwing it away.
Signed-off-by: Jonathan Brassow <jbrassow@redhat.com>
2010-01-09 01:00:31 +03:00
2009-04-23 20:56:21 +04:00
.TP
2007-01-10 17:13:46 +03:00
.I \- s, \- \- snapshot
Create a snapshot from existing logical volume using another
existing logical volume as its origin.
.TP
.I \- c, \- \- chunksize ChunkSize
Power of 2 chunk size for the snapshot logical volume between 4k and 512k.
.TP
2008-11-12 18:01:35 +03:00
.I \- Z, \- \- zero y|n
2007-01-10 17:13:46 +03:00
Controls zeroing of the first KB of data in the snapshot.
2007-01-10 22:56:39 +03:00
If the volume is read-only the snapshot will not be zeroed.
2010-01-13 04:55:05 +03:00
.TP
.I \- \- merge
Merges a snapshot into its origin volume. If both the origin and snapshot volume
are not open the merge will start immediately. Otherwise, the merge will start
the first time either the origin or snapshot are activated and both are closed.
Merging a snapshot into an origin that cannot be closed, for example a root
filesystem, is deferred until the next time the origin volume is activated.
When merging starts, the resulting logical volume will have the origin's name,
minor number and UUID. While the merge is in progress, reads or writes to the
origin appear as they were directed to the snapshot being merged. When the
2010-02-06 01:44:37 +03:00
merge finishes, the merged snapshot is removed. Multiple snapshots may
be specified on the commandline or a @tag may be used to specify
multiple snapshots be merged to their respective origin.
2007-01-10 17:13:46 +03:00
.br
This patch adds the capability to split off a mirror legs.
It is pretty much the same as reducing the number of
mirror legs, but we just don't delete them afterwards.
The following command line interface is enforced:
prompt> lvconvert --splitmirror <n> -n <name> <VG>/<LV>
where 'n' is the number of images to split off, and
where 'name' is the name of the newly split off logical volume.
If more than one leg is split off, a new mirror will be the
result. The newly split off mirror will have a 'core' log.
Example:
[root@bp-01 LVM2]# !lvs
lvs -a -o name,copy_percent,devices
LV Copy% Devices
lv 100.00 lv_mimage_0(0),lv_mimage_1(0),lv_mimage_2(0),lv_mimage_3(0)
[lv_mimage_0] /dev/sdb1(0)
[lv_mimage_1] /dev/sdc1(0)
[lv_mimage_2] /dev/sdd1(0)
[lv_mimage_3] /dev/sde1(0)
[lv_mlog] /dev/sdi1(0)
[root@bp-01 LVM2]# lvconvert --splitmirrors 2 --name split vg/lv /dev/sd[ce]1
Logical volume lv converted.
[root@bp-01 LVM2]# !lvs
lvs -a -o name,copy_percent,devices
LV Copy% Devices
lv 100.00 lv_mimage_0(0),lv_mimage_2(0)
[lv_mimage_0] /dev/sdb1(0)
[lv_mimage_2] /dev/sdd1(0)
[lv_mlog] /dev/sdi1(0)
split 100.00 split_mimage_0(0),split_mimage_1(0)
[split_mimage_0] /dev/sde1(0)
[split_mimage_1] /dev/sdc1(0)
It can be seen that '--splitmirror <n>' is exactly the same
as '--mirrors -<n>' (note the minus sign), except there is the
additional notion to keep the image being detached from the
mirror instead of just throwing it away.
Signed-off-by: Jonathan Brassow <jbrassow@redhat.com>
2010-01-09 01:00:31 +03:00
.TP
.I \- \- repair
Repair a mirror after suffering a disk failure. The mirror will be brought back
into a consistent state. By default, the original number of mirrors will be
restored if possible. Specify \- y on the command line to skip the prompts.
Use \- f if you do not want any replacement. Additionally, you may use
\- \- use-policies to use the device replacement policy specified in lvm.conf,
viz. activation/mirror_log_fault_policy or
activation/mirror_device_fault_policy.
.br
2006-08-19 01:49:19 +04:00
.SH Examples
"lvconvert -m1 vg00/lvol1"
.br
converts the linear logical volume "vg00/lvol1" to
2007-08-10 00:43:29 +04:00
a two-way mirror logical volume.
2006-08-19 01:49:19 +04:00
2007-08-30 23:34:19 +04:00
"lvconvert --mirrorlog core vg00/lvol1"
2006-08-19 01:49:19 +04:00
.br
2007-08-02 01:01:06 +04:00
converts a mirror with a disk log to a
mirror with an in-memory log.
2007-08-30 23:34:19 +04:00
"lvconvert --mirrorlog disk vg00/lvol1"
2007-08-02 01:01:06 +04:00
.br
converts a mirror with an in-memory log
to a mirror with a disk log.
2006-08-19 01:49:19 +04:00
"lvconvert -m0 vg00/lvol1"
.br
converts a mirror logical volume to a linear logical
volume.
2007-01-10 17:13:46 +03:00
.br
.br
"lvconvert -s vg00/lvol1 vg00/lvol2"
.br
converts logical volume "vg00/lvol2" to snapshot of original volume "vg00/lvol1"
2006-08-19 01:49:19 +04:00
2009-08-10 21:23:04 +04:00
.br
"lvconvert -m1 vg00/lvol1 /dev/sda:0-15 /dev/sdb:0-15"
.br
converts linear logical volume "vg00/lvol1" to a two-way mirror, using physical
extents /dev/sda:0-15 and /dev/sdb:0-15 for allocation of new extents.
2009-10-26 16:41:13 +03:00
.br
"lvconvert -m0 vg00/lvmirror1 /dev/sda
.br
converts mirror logical volume "vg00/lvmirror1" to linear, freeing physical
extents from /dev/sda.
2010-01-13 04:55:05 +03:00
.br
"lvconvert --merge vg00/lvol1_snap"
.br
merges "vg00/lvol1_snap" into its origin.
2010-02-06 01:44:37 +03:00
.br
"lvconvert --merge @some_tag"
.br
If vg00/lvol1, vg00/lvol2, and vg00/lvol3 are all tagged with "some_tag"
each snapshot logical volume will be merged serially, e.g.: vg00/lvol1,
then vg00/lvol2, then vg00/lvol3. If --background were used it would start
all snapshot logical volume merges in parallel.
2006-08-19 01:49:19 +04:00
.SH SEE ALSO
.BR lvm (8),
.BR vgcreate (8),
.BR lvremove (8),
.BR lvrename (8),
.BR lvextend (8),
.BR lvreduce (8),
.BR lvdisplay (8),
.BR lvscan (8)