서버에는 몇 가지 볼륨이 있는 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
읽어 주셔서 감사합니다! 어떤 조언이라도 감사하겠습니다.
답변1
씬 LVM 아카이브 파일 /etc/lvm/archive/*.vg에는 세그먼트에 물리적 범위가 없고 device_id만 있습니다. 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_ids가 없는 것을 볼 수 있습니다.
따라서 설명된 경우에는 Thin 복구가 불가능합니다.
또한보십시오개발자 피드백(2014).