サーバーには、いくつかのボリュームを持つシン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
...
削除されたボリュームの「使用可能なデータがありません」。悲しい。 AFAIKtpoolには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のみがあります。 LVMメタデータに保存され、非アクティブなプールからダンプできるブロックデバイス上のdevice_idsと物理エクステントの間のマッピング:
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_idは表示されません。
したがって、説明されているケースでは、シンリカバリは不可能です。
開発者フィードバック(2014) も参照してください。