Recovering a VM Disk Image with fsck
Recovering a qcow2 image using fsck #
This was found as a gist here. I’m adapting it for proxmox nuances.
PreReqs #
Load network block device module if necessary #
the nbd kernel module is needed for this… do we have it enabled?
if [[ $(/usr/sbin/lsmod|grep -c nbd) == 1 ]]; then
echo 'Kernel module already loaded';
else
echo "The nbd kernel module is not loaded. We need to load it."
sudo /usr/sbin/modprobe nbd max_part=8
fi
Poweroff machine (if necessary) #
virsh destroy virtual-machine
Connect disk image: #
qemu-nbd --connect=/dev/nbd0 /var/lib/libvirt/images/virtual-machine.qcow2
Check disk: #
fdisk -l /dev/nbd0
Disk /dev/nbd0: 488.28 GiB, 524288000000 bytes, 1024000000 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: gpt
Disk identifier: 3E5BE263-297E-4E22-AA5D-CBBD412D5898
Device Start End Sectors Size Type
/dev/nbd0p1 470056960 486834175 16777216 8G Microsoft basic data
/dev/nbd0p2 1005123584 1021900799 16777216 8G Microsoft basic data
/dev/nbd0p3 2048 2099199 2097152 1G BIOS boot
/dev/nbd0p4 1021900800 1023997951 2097152 1G Microsoft basic data
/dev/nbd0p5 2099200 470056959 467957760 223.1G Microsoft basic data
/dev/nbd0p6 537165824 1005123583 467957760 223.1G Microsoft basic data
/dev/nbd0p7 486834176 537165823 50331648 24G Linux swap
iterate thru the partitions with filesystems #
for fs in 1 2 4 5 6; do
date;
echo "/dev/nbd0p${fs}"
fsck -y /dev/nbd0p${fs}
done
fsck from util-linux 2.25.2
e2fsck 1.42.12 (29-Aug-2014)
/dev/nbd0p1: recovering journal
/dev/nbd0p1 contains a file system with errors, check forced.
Pass 1: Checking inodes, blocks, and sizes
Inodes that were part of a corrupted orphan linked list found. Fix<y>? yes
Inode 274 was part of the orphaned inode list. FIXED.
Inode 132276 was part of the orphaned inode list. FIXED.
Deleted inode 142248 has zero dtime. Fix<y>? yes
Pass 2: Checking directory structure
Pass 3: Checking directory connectivity
Pass 4: Checking reference counts
Pass 5: Checking group summary information
Block bitmap differences: -603674 -623174 +(689342--689343)
Fix<y>? yes
Free blocks count wrong for group #18 (15076, counted=15077).
Fix<y>? yes
Free blocks count wrong for group #19 (11674, counted=11675).
Fix<y>? yes
Free blocks count wrong (632938, counted=670871).
Fix<y>? yes
Inode bitmap differences: -274 -132276 -142248
Fix<y>? yes
Free inodes count wrong for group #0 (52, counted=53).
Fix<y>? yes
Free inodes count wrong for group #16 (99, counted=100).
Fix<y>? yes
Free inodes count wrong for group #17 (519, counted=520).
Fix<y>? yes
Free inodes count wrong (204392, counted=204599).
Fix<y>? yes
/dev/nbd0p1: ***** FILE SYSTEM WAS MODIFIED *****
/dev/nbd0p1: 101833/306432 files (0.2% non-contiguous), 553321/1224192 blocks
Disconnect device: #
# qemu-nbd --disconnect /dev/nbd0
/dev/nbd0 disconnected
Start machine: #
# virsh start virtual-machine