Re: Can't work normally after attaching disk volumes originally in a VG on another machine

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Dne 26.3.2018 v 08:04 Gang He napsal(a):
Hi Xen,



Gang He schreef op 23-03-2018 9:30:

6) attach disk2 to VM2(tb0307-nd2), the vg on VM2 looks abnormal.
tb0307-nd2:~ # pvs
   WARNING: Device for PV JJOL4H-kc0j-jyTD-LDwl-71FZ-dHKM-YoFtNV not
found or rejected by a filter.
   PV         VG  Fmt  Attr PSize  PFree
   /dev/vdc   vg2 lvm2 a--  20.00g 20.00g
   /dev/vdd   vg1 lvm2 a--  20.00g 20.00g
   [unknown]  vg1 lvm2 a-m  20.00g 20.00g

This is normal because /dev/vdd contains metadata for vg1 which includes
now missing disk /dev/vdc      .... as the PV is no longer the same.




tb0307-nd2:~ # vgs
   WARNING: Device for PV JJOL4H-kc0j-jyTD-LDwl-71FZ-dHKM-YoFtNV not
found or rejected by a filter.
   VG  #PV #LV #SN Attr   VSize  VFree
   vg1   2   0   0 wz-pn- 39.99g 39.99g
   vg2   1   0   0 wz--n- 20.00g 20.00g

This is normal because you haven't removed /dev/vdc from vg1 on
/dev/vdd, since it was detached while you operated on its vg.


7) reboot VM2, the result looks worse (vdc disk belongs to two vg).
tb0307-nd2:/mnt/shared # pvs
   PV         VG  Fmt  Attr PSize  PFree
   /dev/vdc   vg1 lvm2 a--  20.00g     0
   /dev/vdc   vg2 lvm2 a--  20.00g 10.00g
   /dev/vdd   vg1 lvm2 a--  20.00g  9.99g

When you removed vdd when it was not attached, the VG1 metadata on vdd
was not altered. The metadata resides on both disks, so you had
inconsistent metadata between both disks because you operated on the
shared volume group while one device was missing.

You also did not recreate PV on /dev/vdc so it has the same UUID as when
it was part of VG1, this is why VG1 when VDD is booted will still try to
include /dev/vdc because it was never removed from the volume group on
VDD.

So the state of affairs is:

/dev/vdc contains volume group info for VG2 and includes only /dev/vdc

/dev/vdd contains volume group info for VG1, and includes both /dev/vdc
and /dev/vdd by UUID for its PV, however, it is a bug that it should
include /dev/vdc even though the VG UUID is now different (and the name
as well).
It looks like each PV includes a copy meta data for VG, but if some PV has changed (e.g. removed, or moved to another VG),
the remained PV should have a method to check the integrity when each startup (activated?), to avoid such inconsistent problem automatically.




Hi

I'm not really sure what are you trying to achieve - are you 'validating' that you cannot foolish lvm2 too easily or something else ?

Simple case is when you have a VG on 2 PV disks. Both PV hold full metadata for a VG. There are numerous other case - i.e. you can have 1000PVs in single VG then any update of metadata would require to update 1000 disks - for this case you can select lower number metadata copies - i.e. randomly or user-selected PVs only hold VG metadata and rest of PV are without metadata.
The less metadata copies - the less secure it is, but update is faster...


There are no metadata for use stored in your filesystem - VG metadata are always recorded in PV metadata area.


1.) So when you 1st. remove device and then you run 'pvremove' on this missing disk, it's kind of pointless operation.

2.) lvm2 command will not let you 'easily' remove PV which is in use by some LV in your VG

3.) lvm2 supports 2 commands:
  'vgreduce --removemissing'    (try to make consistent VG when PV is lost)
  'vgextend --restoeremissing'  (restore missing PV back into VG)


Regards

Zdenek

_______________________________________________
linux-lvm mailing list
linux-lvm@redhat.com
https://www.redhat.com/mailman/listinfo/linux-lvm
read the LVM HOW-TO at http://tldp.org/HOWTO/LVM-HOWTO/



[Index of Archives]     [Gluster Users]     [Kernel Development]     [Linux Clusters]     [Device Mapper]     [Security]     [Bugtraq]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]

  Powered by Linux