[linux-lvm] "lvconvert --mirrors 1 --stripes 3 vgtest/lvtest" command succeeds, but no stripes

Zdenek Kabelac zkabelac at redhat.com
Thu May 16 10:55:14 UTC 2019


Dne 16. 05. 19 v 11:03 Gang He napsal(a):
> Hello Guys,
> 
> I found lvconvert command (in lvm lvm2-2.02.120) did not handle "--stripes" option correctly.
> The reproduce steps are as below,
> # vgcreate vgtest /dev/vdb /dev/vdc /dev/vdd /dev/vde /dev/vdf /dev/vdg
> # lvcreate -n lvtest -L 8G vgtest
> # lvconvert --mirrors 1 --stripes 3 vgtest/lvtest
> # lvs -o+stripes
>    LV     VG     Attr       LSize Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert #Str
>    lvtest vgtest rwi-a-r--- 8.00g                                    12.21               2
> 
> But if you create LV using lvcreate command directly, the command succeeds with stripes.
> e.g.
> # lvcreate --mirrors 1 --stripes 3 -L 4G vgtest
> # lvs -o+stripes
>    LV     VG     Attr       LSize Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert #Str
>    lvol0  vgtest rwi-a-r--- 4.01g                                    8.67                6
> 
> I also use lvm2-2.02.180 to reproduce this issue, the lvconvert command works like before,
> but the command will print out a message, like that,
> # lvconvert --mirrors 1 --stripes 3 vgtest/lvtest
>    Command does not accept option: --stripes 3.
> 
> Why do we can not use lvconvert to do like that, design issue? but lvcreate can do that.
> What limitations are there between mirrors and stripes?

Layout of disks with raid target is:

1st. + 2nd.     are paired into raid1

3rd. + 4th.     are paired into raid1

5th. + 6th.     are making 3rd. raid1

then with your --stripe option - above raid1-like-devices are combined into 
one big raid0 array   (aka raid10) (all happens within single device target)

So converting ordinary LV into such beast is not trivial.
Although I believe you should look at reshaping possibilities, but I'm not 
quite sure there is already support for raid10.

In past with old --type mirror target the logic was different - you had 
'individual' mirror legs striped - and then from them it's been mirrored/raid1 
(aka raid01). Clearly old mechanism (where you only say you add new 'striped' 
leg) is way more easier for implementation - you just allocate striped LV and 
add as a new leg to mirror.

Regards

Zdenek




More information about the linux-lvm mailing list