Lvm

vgcfgrestore 獲得後的 LVM:設備映射器:重新載入 ioctl on (254:19) 失敗:無可用數據

  • January 31, 2020

伺服器具有帶有幾個卷的 Thin LVM:

vm-130-disk-0 - was deleted and need to be restored.
vm-137-disk-0 - was NOT deleted.

嘗試恢復在刪除之前創建的 /etc/lvm/archive/pve_00336-2034680334.vg:

# vgcfgrestore --force --file /etc/lvm/archive/pve_00336-2034680334.vg pve
# vgimport pve
# lvchange -ay /dev/pve/vm-130-disk-0
     Thin pool pve-data-tpool (254:6) transaction_id is 324, while expected 311.
     ...

# lvs -a              
 LV              VG   Attr       LSize   Pool Origin Data%  Meta%
 data            pve  twi---tz--   1.57t      # NOT activated pool data
 [data_tdata]    pve  Twi-a-----   1.57t      # OK  a=Activated
 [data_tmeta]    pve  ewi-a-----  16.00g      # OK  a=Activated                                              
 root            pve  -wi-a-----  10.00g      # OK  a=Activated                                 
 vm-130-disk-0   pve  Vwi---tz--  32.00g data # NOT activated deleted volume
 vm-137-disk-0   pve  Vwi---tz--  22.00g data # NOT activated non-deleted volume
 ...

好吧,這裡我們失敗了,因為 tmeta 和 tpool 之間的事務不匹配。網際網路上大多數回答的人都有鏡像情況:tpool=312 和 tmeta=324,看起來像 .vg 文件中的 transaction_id 修復對他們有幫助。讓我們嘗試修復 .vg 文件並啟動:

Changed by hands transaction_id from 311 to 324 in /etc/lvm/archive/pve_00336-2034680334.vg ..

# vgcfgrestore --force --file /etc/lvm/archive/pve_00336-2034680334.vg pve
# vgimport pve
# lvchange -ay /dev/pve/vm-130-disk-0
  device-mapper: reload ioctl on (254:19) failed: No data available

In debug log appears: pve-vm--130--disk--0: Skipping NODE_DEL [trust_udev]

# lvs -a
 LV              VG   Attr       LSize   Pool Origin Data%  Meta%
 data           pve  twi-aotz--   1.57t             5.86   0.44  # OK
 [data_tdata]   pve  Twi-a-----   1.57t                          # OK                      
 [data_tmeta]   pve  ewi-a-----  16.00g                          # OK                      
 root           pve  -wi-a-----  10.00g                          # OK                      
 vm-130-disk-0  pve  Vwi---tz--  32.00g data                     # NOT activated deleted volume
 vm-137-disk-0  pve  Vwi-a-tz--  22.00g data        67.91        # OK activated non-deleted volume
 ...

已刪除卷的“無可用數據”。傷心。AFAIK tpool 有 transaction_id=324,我需要以某種方式將 tpool 回滾到 312。不知道怎麼做。

我可以用什麼啟動 pve/vm-130-disk-0 ?

# lvm version
 LVM version:     2.02.168(2) (2016-11-30)
 Library version: 1.02.137 (2016-11-30)
 Driver version:  4.35.0

# uname -a
Linux adminslotlogicrestoreasap 4.9.0-11-amd64 #1 SMP Debian 4.9.189-3+deb9u2 (2019-11-11) x86_64 GNU/Linux

謝謝閱讀!我將不勝感激任何建議。

精簡 LVM 歸檔文件 /etc/lvm/archive/*.vg 在段中沒有物理範圍,而只有 device_ids。device_ids 和儲存在 LVM 元數據中的塊設備上的物理範圍之間的映射,可以從非活動池中轉儲:

vgimport pve
lvchange --yes -ay pve/data_tmeta
thin_dump  /dev/mapper/pve-data_tmeta -o thin_dump_pve-data_tmeta.xml
lvchange       -an pve/data_tmeta

感謝lvremove,您可以看到沒有刪除的 device_ids。

因此,在所描述的情況下,無法進行精簡恢復。

另請參閱開發者回饋 (2014)

引用自:https://serverfault.com/questions/1000936