jthornber/thin-provisioning-tools

"Check of pool vg/thinpool failed (status:64). Manual repair required!"

mailinglists35 opened this issue · 34 comments

Hi,
I am experiencing this after a power loss (but not sure if actually the power loss was the cause). The root filesystem is on a thin LV and the LV fails to activate (so I cannot even read the logs of what happened before).

Commands below while booted with sysresccd v10 iso.

Is this a correctable/repairable issue, and if yes, how? If not repairable, is there any way to rescue the LV data?

Thank you

[root@sysrescue ~]# lvmconfig
config {
}
local {
}
dmeventd {
}
activation {
        thin_pool_autoextend_threshold=90
        thin_pool_autoextend_percent=5
}
global {
        thin_check_options=["--ignore-non-fatal-errors","--clear-needs-check-flag"]
}
shell {
}
backup {
}
log {
        activation=1
}
allocation {
}
devices {
}

[root@sysrescue ~]# uname -r
6.1.20-1-lts
[root@sysrescue ~]# thin_check --version
thin_check 1.0.3

[root@sysrescue ~]# pvs
  PV         VG     Fmt  Attr PSize  PFree
  /dev/sdd2  mainvg lvm2 a--  <1.82t 870.23g

[root@sysrescue ~]# lvs -v 
  LV          VG     #Seg Attr       LSize    Maj Min KMaj KMin Pool     Origin Data%  Meta%  Move Cpy%Sync Log Convert LV UUID
LProfile
  exos.zcache mainvg    1 Vwi---tz--   32.00g  -1  -1   -1   -1 thinpool                                                JaPbHo-P7Te-cF8Y-cble-eEmf-Qy8Q-tACOsk

  exos.zlog   mainvg    1 Vwi---tz--    4.00g  -1  -1   -1   -1 thinpool                                                UGwx7D-XZlj-NrFM-fgpO-q5qD-PqAA-3g5ycF

  rootfs      mainvg    1 Vwi---tz--  128.00g  -1  -1   -1   -1 thinpool                                                ca9iq6-MYe3-qOdQ-XE5h-fSbN-nOh0-3eKWtq

  small       mainvg    1 Vwi---tz--   64.00g  -1  -1   -1   -1 thinpool                                                jEguxm-Cbvu-AVO9-bEsj-16wl-Z7aQ-mZqyAm

  swap        mainvg    1 Vwi---tz--   32.00g  -1  -1   -1   -1 thinpool                                                dEmPCV-r4oX-BTKU-DzWC-NXFt-tcDg-d2S0EU

  thinpool    mainvg    1 twi---tz-- <988.10g  -1  -1   -1   -1                                                         6URKTy-2232-vNXZ-itDX-3wxa-s445-b3XfNS thin-performance
  windows_vm  mainvg    1 Vwi---tz-- <256.13g  -1  -1   -1   -1 thinpool                                                NzKsD7-7X7g-uRXr-WCkx-zb2G-Rlio-rClJuh

  zfs.cache   mainvg    1 Vwi---tz--  256.00g  -1  -1   -1   -1 thinpool                                                hVL6CS-vMfd-k4dJ-2w2D-UGGc-aIUD-Oeg3S1

  zfs.logs    mainvg    1 Vwi---tz--    4.00g  -1  -1   -1   -1 thinpool                                                27nZ91-hLsX-FOHh-qVJR-h3Rw-snpq-6USe52

[root@sysrescue ~]# lvchange -ay mainvg/thinpool
TRANSACTION_ID=32
METADATA_FREE_BLOCKS=57711
1 nodes in data mapping tree contain errors
0 io errors, 0 checksum errors
Thin device 1 has 1 error nodes and is missing 17817 mappings, while expected 142318
Check of mappings failed
  Check of pool mainvg/thinpool failed (status:64). Manual repair required!

[root@sysrescue ~]# lvchange -vvvvay mainvg/rootfs
[attached because github allows maximum 65536 chars]

lvchange-vvvay.txt

Attached lvmdump as well
lvmdump-sysrescue-20230526204414.zip

I've read #164 and https://access.redhat.com/solutions/3251681 but they address the status 1, while I have status 64

[root@sysrescue ~]# thin_dump --repair /dev/mapper/mainvg-thinpool_tmeta > /tmp/repaired.xml
node error: keys out of order BASVugEAEQ==
[root@sysrescue ~]# lvchange -ay mainvg/thinpool_tmeta
Do you want to activate component LV in read-only mode? [y/n]: y
  Allowing activation of component LV.

[root@sysrescue ~]# lvcreate -L1024M mainvg --name newmetaLV
  /dev/mainvg/newmetaLV: not found: device not cleared
  Aborting. Failed to wipe start of new LV.

Hi,

We had addressed this issue in the recent commit. Could you please try building the pdata_tools binary, then run thin_dump --repair again?

Here's the build instruction. You might have to build it on another machine, then copy the built binary to your rescue environment via an USB drive or something.
https://listman.redhat.com/archives/lvm-devel/2023-May/024788.html

thank you. I am in the middle of reinstalling the os on a separate drive, then once it's up I will attach the affected original drive and try the guide. will come back with feedback.

$ sudo ./pdata_tools thin_dump --repair /dev/mapper/mainvg-thinpool_tmeta
no compatible roots found

I have setup a dnf chroot in OL9 and built it, but getting above output when running pdata_tools:

sudo -E dnf --installroot=/var/local/ol9chroot/ --releasever=9 group install minimal-environment
sudo systemd-nspawn -D /var/local/ol9chroot/
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
yum install git
git clone https://github.com/jthornber/thin-provisioning-tools.git
cd thin-provisioning-tools/
yum install cargo
cargo build --release
# cargo build --release
    Updating crates.io index
    Updating git repository `https://github.com/zowens/crc32c`
    Updating git repository `https://github.com/jthornber/rio`
  Downloaded futures-io v0.3.28
  Downloaded memchr v2.5.0
  Downloaded autocfg v1.1.0
  Downloaded rustc_version v0.4.0
  Downloaded termcolor v1.2.0
  Downloaded semver v1.0.17
  Downloaded minimal-lexical v0.2.1
  Downloaded thiserror-impl v1.0.40
  Downloaded flate2 v1.0.25
  Downloaded cfg-if v1.0.0
  Downloaded atty v0.2.14
  Downloaded clap v3.2.23
  Downloaded futures-executor v0.3.28
  Downloaded futures-task v0.3.28
  Downloaded indexmap v1.9.3
  Downloaded hashbrown v0.12.3
  Downloaded futures-sink v0.3.28
  Downloaded data-encoding v2.3.3
  Downloaded clap_lex v0.2.4
  Downloaded miniz_oxide v0.6.2
  Downloaded pin-utils v0.1.0
  Downloaded ppv-lite86 v0.2.17
  Downloaded rand v0.8.5
  Downloaded rand_core v0.6.4
  Downloaded rand_chacha v0.3.1
  Downloaded quote v1.0.26
  Downloaded proc-macro2 v1.0.56
  Downloaded indicatif v0.17.3
  Downloaded slab v0.4.8
  Downloaded unicode-segmentation v1.10.1
  Downloaded zstd-safe v5.0.2+zstd.1.5.2
  Downloaded byteorder v1.4.3
  Downloaded unicode-width v0.1.10
  Downloaded zstd v0.11.2+zstd.1.5.2
  Downloaded unicode-ident v1.0.8
  Downloaded futures-channel v0.3.28
  Downloaded crc32fast v1.3.2
  Downloaded jobserver v0.1.26
  Downloaded number_prefix v0.4.0
  Downloaded num-derive v0.3.3
  Downloaded lazy_static v1.4.0
  Downloaded portable-atomic v0.3.19
  Downloaded thiserror v1.0.40
  Downloaded threadpool v1.8.1
  Downloaded roaring v0.10.1
  Downloaded retain_mut v0.1.7
  Downloaded tui v0.16.0
  Downloaded termion v1.5.6
  Downloaded numtoa v0.1.0
  Downloaded rangemap v1.3.0
  Downloaded zstd-sys v2.0.8+zstd.1.5.5
  Downloaded quick-xml v0.23.1
  Downloaded libc v0.2.142
  Downloaded syn v1.0.109
  Downloaded textwrap v0.16.0
  Downloaded futures-core v0.3.28
  Downloaded anyhow v1.0.70
  Downloaded getrandom v0.2.9
  Downloaded futures-util v0.3.28
  Downloaded futures-macro v0.3.28
  Downloaded console v0.15.5
  Downloaded fixedbitset v0.4.2
  Downloaded cc v1.0.79
  Downloaded bitflags v1.3.2
  Downloaded bytemuck v1.13.1
  Downloaded adler v1.0.2
  Downloaded syn v2.0.15
  Downloaded strsim v0.10.0
  Downloaded safemem v0.3.3
  Downloaded pkg-config v0.3.26
  Downloaded os_str_bytes v6.5.0
  Downloaded pin-project-lite v0.2.9
  Downloaded num_cpus v1.15.0
  Downloaded num-traits v0.2.15
  Downloaded nom v7.1.3
  Downloaded iovec v0.1.4
  Downloaded futures v0.3.28
  Downloaded exitcode v1.1.2
  Downloaded cassowary v0.3.0
  Downloaded base64 v0.20.0
  Downloaded 80 crates (4.9 MB) in 1.59s
  Downloaded duct v0.13.6
  Downloaded 1 crate (29.3 KB) in 0.17s
  Downloaded json v0.12.4
  Downloaded 1 crate (105.9 KB) in 0.16s
  Downloaded mockall v0.11.4
  Downloaded 1 crate (22.4 KB) in 0.15s
  Downloaded quickcheck v0.9.2
  Downloaded 1 crate (27.4 KB) in 0.90s
  Downloaded quickcheck_macros v0.9.1
  Downloaded 1 crate (4.2 KB) in 0.79s
  Downloaded tempfile v3.5.0
  Downloaded 1 crate (31.1 KB) in 0.16s
   Compiling libc v0.2.142
   Compiling autocfg v1.1.0
   Compiling proc-macro2 v1.0.56
   Compiling unicode-ident v1.0.8
   Compiling quote v1.0.26
   Compiling memchr v2.5.0
   Compiling pkg-config v0.3.26
   Compiling cfg-if v1.0.0
   Compiling semver v1.0.17
   Compiling futures-core v0.3.28
   Compiling futures-task v0.3.28
   Compiling futures-channel v0.3.28
   Compiling futures-util v0.3.28
   Compiling slab v0.4.8
   Compiling futures-sink v0.3.28
   Compiling indexmap v1.9.3
   Compiling rustc_version v0.4.0
   Compiling syn v2.0.15
   Compiling pin-project-lite v0.2.9
   Compiling pin-utils v0.1.0
   Compiling syn v1.0.109
   Compiling getrandom v0.2.9
   Compiling jobserver v0.1.26
   Compiling portable-atomic v0.3.19
   Compiling zstd-safe v5.0.2+zstd.1.5.2
   Compiling crc32fast v1.3.2
   Compiling cc v1.0.79
   Compiling futures-io v0.3.28
   Compiling crc32c v0.6.3 (https://github.com/zowens/crc32c?branch=master#3779fe88)
   Compiling rand_core v0.6.4
   Compiling num-traits v0.2.15
   Compiling thiserror v1.0.40
   Compiling hashbrown v0.12.3
   Compiling anyhow v1.0.70
   Compiling os_str_bytes v6.5.0
   Compiling adler v1.0.2
   Compiling ppv-lite86 v0.2.17
   Compiling unicode-width v0.1.10
   Compiling lazy_static v1.4.0
   Compiling console v0.15.5
   Compiling clap_lex v0.2.4
   Compiling miniz_oxide v0.6.2
   Compiling rand_chacha v0.3.1
   Compiling num_cpus v1.15.0
   Compiling atty v0.2.14
   Compiling textwrap v0.16.0
   Compiling zstd-sys v2.0.8+zstd.1.5.5
   Compiling byteorder v1.4.3
   Compiling minimal-lexical v0.2.1
   Compiling bytemuck v1.13.1
   Compiling bitflags v1.3.2
   Compiling number_prefix v0.4.0
   Compiling strsim v0.10.0
   Compiling retain_mut v0.1.7
   Compiling termcolor v1.2.0
   Compiling clap v3.2.23
   Compiling roaring v0.10.1
   Compiling indicatif v0.17.3
   Compiling nom v7.1.3
   Compiling threadpool v1.8.1
   Compiling flate2 v1.0.25
   Compiling rand v0.8.5
   Compiling num-derive v0.3.3
   Compiling iovec v0.1.4
   Compiling futures-macro v0.3.28
   Compiling thiserror-impl v1.0.40
   Compiling quick-xml v0.23.1
   Compiling rangemap v1.3.0
   Compiling data-encoding v2.3.3
   Compiling fixedbitset v0.4.2
   Compiling base64 v0.20.0
   Compiling exitcode v1.1.2
   Compiling safemem v0.3.3
   Compiling futures-executor v0.3.28
   Compiling futures v0.3.28
   Compiling zstd v0.11.2+zstd.1.5.2
   Compiling thinp v1.0.4 (/root/thin-provisioning-tools)
    Finished release [optimized + debuginfo] target(s) in 4m 03s

then exit the chroot, cd /var/local/ol9chroot/root/thin-provisioning-tools/target/release and run ./pdata_tools

$ sudo ./pdata_tools thin_dump --repair /dev/mapper/mainvg-thinpool_tmeta
no compatible roots found

Could you help run thin_dump with option -v please?
./pdata_tools thin_dump -v --repair /dev/mapper/mainvg-thinpool_tmeta

If possible, could you help send me the compressed metadata file for me to take a look?
./pdata_tools thin_metadata_pack -i /dev/mapper/mainvg-thinpool_tmeta -o tmeta.pack

I have just experienced a "Check of pool qubes_dom0/root-pool failed (status:64). Manual repair required!" in an entirely different context (I'm not using this repo at all, I'm trying to recover a broken qubes os). I find it interesting that this was the only hit on google for this error with status:64 on this issue and it's happening in the last few days to someone else too. Must be a recent bug perhaps in LVM. I'm on ArchLinux.

If you're talking about the status code itself, it's because the recently released thin-provisioning-tools v1.0.x uses a different exit code rather than 1 as in the previous versions. That's why you don't see much search results with status:64 so far. You could run LVM commands with -vvv to make sure the status:64 was came from thin_check.

On the other hand, the new thin_check performs a more comprehensive check on the metadata, so you might experiences errors after upgrading the tools. You could choose either fix or ignores those non-fatal errors, by using options --auto-repair or --ignore-non-fatal-errors. See issue #242 for more information.

Oh, I entirely misunderstood. Yes, these thin_* things are on ArchLinux. I didn't realize. Anyhow, I did my LVM stuff on an older system and had no issues, I just thought my data point might be relevant, but let me not hijack this. Good luck.

$ sudo ./pdata_tools thin_dump --repair /dev/mapper/mainvg-thinpool_tmeta
no compatible roots found

Could you help run thin_dump with option -v please? ./pdata_tools thin_dump -v --repair /dev/mapper/mainvg-thinpool_tmeta

If possible, could you help send me the compressed metadata file for me to take a look? ./pdata_tools thin_metadata_pack -i /dev/mapper/mainvg-thinpool_tmeta -o tmeta.pack

sure.
here is the output:

$ sudo ./pdata_tools thin_dump -v --repair /dev/mapper/mainvg-thinpool_tmeta
mapping candidates (0):

device candidates (2639):
b=148, nr_devices=8, nr_mappings=9231990, max_tid=30, age=1
b=306, nr_devices=8, nr_mappings=9231736, max_tid=30, age=1
#[...] long list text suppressed
b=128272, nr_devices=8, nr_mappings=9234495, max_tid=30, age=1
b=128610, nr_devices=8, nr_mappings=9233372, max_tid=30, age=1
b=128936, nr_devices=8, nr_mappings=9232379, max_tid=30, age=1

compatible roots (0):
no compatible roots found

here is the uploaded tmeta.pack: https://pastefile.com/ftcc83 34MB (github only alllows 25MB), password is case sensitive exactly the name that appears under your github profile including dash and space

note you will observe that the vg name is actually different but wanted to protect it's name online.

Hi,

I would like to know, is the data in the thin device with id#0 valuable? The thin device 0 was affected by few broken metadata blocks, while others are fine. The easiest way to rebuild the metadata is to drop the thin device 0, so you could still have other volumes readable. If this way is not acceptable, I could help recover the mappings for the device 0.

I am unsure how do I identify device with id#0 inside the thin pool, but if they are sorted by id, and id#0 is the first on the list, it can be safely dropped (exos.zcache):

  LV               VG     Attr       LSize    Pool     Origin Data%  Meta%  Move Log Cpy%Sync Convert
  exos.zcache      mainvg Vwi---tz--   32.00g thinpool
  exos.zlog        mainvg Vwi---tz--    4.00g thinpool
  [lvol0_pmspare]  mainvg ewi-------  136.00m
  rootfs           mainvg Vwi---tz--  128.00g thinpool
  small            mainvg Vwi---tz--   64.00g thinpool
  swap             mainvg Vwi---tz--   32.00g thinpool
  thinpool         mainvg twi---tz-- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  windows_vm       mainvg Vwi---tz-- <256.13g thinpool
  zfs.cache        mainvg Vwi---tz--  256.00g thinpool
  zfs.logs         mainvg Vwi---tz--    4.00g thinpool

oh, they're sorted alphabetically. does the metadata allow you to map the id to one of the names above?

lvs manual page only says how to sort, but no detail what criterias are available to sort

       -O|--sort String
              Comma-separated  ordered  list of columns to sort by. Replaces the default selection. Precede any column with - for a re‐
              verse sort on that column.

oh, it displays them on -O anytexthere
maybe this? but I see no 0 id, they begin with 1?

$ sudo lvs -a mainvg -O thin_id -o+thin_id
  LV               VG     Attr       LSize    Pool     Origin Data%  Meta%  Move Log Cpy%Sync Convert ThId
  swap             mainvg Vwi---tz--   32.00g thinpool                                                   1
  rootfs           mainvg Vwi---tz--  128.00g thinpool                                                   2
  small            mainvg Vwi---tz--   64.00g thinpool                                                   3
  zfs.logs         mainvg Vwi---tz--    4.00g thinpool                                                   4
  zfs.cache        mainvg Vwi---tz--  256.00g thinpool                                                   5
  windows_vm       mainvg Vwi---tz-- <256.13g thinpool                                                   7
  exos.zcache      mainvg Vwi---tz--   32.00g thinpool                                                   8
  exos.zlog        mainvg Vwi---tz--    4.00g thinpool                                                   9
  thinpool         mainvg twi---tz-- <988.10g
  [lvol0_pmspare]  mainvg ewi-------  136.00m
  [lvol0_pmspare]  mainvg ewi-------  136.00m
  [lvol0_pmspare]  mainvg ewi-------  136.00m
  [lvol0_pmspare]  mainvg ewi-------  136.00m
  [lvol0_pmspare]  mainvg ewi-------  136.00m
  [lvol0_pmspare]  mainvg ewi-------  136.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tmeta] mainvg eRi-a-----  504.00m
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g
  [thinpool_tdata] mainvg Twi------- <988.10g

if swap is the thin device 0, then yes it can be safely abandoned

oh, it displays them on -O anytexthere maybe this? but I see no 0 id, they begin with 1?

my mistake... you're right, it's the swap volume with thin_id 1.

You can choose the devices you want with the --dev-id option, e.g., we want to dump all the devices except the id-1.

./pdata_tools thin_dump tmeta.bin  --dev-id 2 --dev-id 3 --dev-id 4 --dev-id 5 --dev-id 7 --dev-id 8 --dev-id 9 -o dump.xml

(I know it looks stupid especially when you have hundreds of devices, just because the option was not designed for restoration)

The md5sum for dump.xml is 0f8253a136a52131c494bbc0f2e04bac

In addition, if you would like to make the swap volume available (but empty), just put the following two lines after the <superblock> tag:

  <device dev_id="1" mapped_blocks="142318" transaction="4" creation_time="0" snap_time="0">
  </device>

Restore metadata into a newly created metadata volume, swap it into the thin-pool, and you should be able to access the pool.

lvcreate mainvg --size 512m --name oldmeta
thin_restore -i dump.txt -o /dev/mapper/mainvg-oldmeta
lvconvert mainvg/thinpool --swapmetadata --poolmetadata mainvg/oldmeta

thank you so much!

I am now waiting for full disk dd backup to finish then I will report back the result of restore

done! final step was to lvremove oldmeta, then I vgchange -an mainvg / vgchange -ay mainvg and lvchange -ay. thank you so much @mingnus !

if anyone else hits this particular case, the tmeta.bin referenced above is actually the dev mapper meta lv name - dev has used it on a plain file to reproduce and solve the issue.

as a followup suggestion, do you think the work you did to identify which lv are recoverable can be automated so then can be merged into the project? so to be able to list the recoverable lv's with some command, then run the thin_dump dev-id command

Sure, it's worth to make it fully automated. I would prefer turn it into a new tool like thin_rescue or something, to avoid being confused with the current thin_dump/thin_repair.

Another question from me: What's the distro & kernel version you had used to run the thin-pool? Had you experienced similar errors before? (where thin_check doesn't pass)

it was ubuntu 18.04 with hwe kernel 5.15

never experienced such situation, (I did not have automatic shutdown configured and when the power went off and I knew I am on UPS borrowed time, I started manually shutting down services instead of issuing a poweroff. the ups died before finishing my manual services stop routine - there must have been something writing to swap at that time, which was the corrupted lv).

PS: and to anyone else reading here, yes, I had the write cache enabled. if you care about your data, don't do like me; disable write cache OR ensure your power redundacy works until shutdown.

How were you able to determine the problematic thin ID above? I'm currently running into the same issue with "no compatible roots found".

The thin_check v1.0.x does the job. It shows that device ID#1 was affected in this case:

TRANSACTION_ID=32
METADATA_FREE_BLOCKS=57711
1 nodes in data mapping tree contain errors
0 io errors, 0 checksum errors
Thin device 1 has 1 errors and is missing 17817 mappings, while expected 142318
Check of mappings failed

Once I've identified the bad devices, is there any hope of doing a manual cleanup on my own? --auto-repair identifies that there is a bad superblock, and thin_check sees issues in two different devices (they are both proxmox vms, so things I'd like to try to recover).

If there's any mapping candidate listed in thin_dump --repair -v, you could try the recent upstream commit that helps repair the device details tree. Alternatively, you could dump incomplete mappings with thin_dump v0.9.0 if you accept the risk of data loss (this feature is a bit tricky so it's removed from v1.0). Or you could send me the packed metadata if you're not sure what to do.

Running thin_dump resulted in the same "no compatible roots" issue above.

Running thin_metadata_pack produced a file, but also a generic I/O error on completion.

The .pack file is at pastefile.com/dw24dd

user@debian:~$ sudo thin_check /dev/mapper/pve-data_tmeta --auto-repair -v
TRANSACTION_ID=105
METADATA_FREE_BLOCKS=373659
number of devices to check: 9
nr internal nodes: 22
nr leaves: 2978
Thin device 5 has 1 errors and is missing 247 mappings, while expected 68360
Thin device 7 has 17 errors and is missing 3348 mappings, while expected 130056
Check of mappings failed

What kind of error messages did you get from thin_metadata_pack? I'm wondering there's io error in reading the source metadata device and therefore I get different thin_check outputs than yours:

# thin_check -v tmeta.bin
TRANSACTION_ID=105
METADATA_FREE_BLOCKS=373659
number of devices to check: 9
nr internal nodes: 18
nr leaves: 1614
742 nodes in data mapping tree contain errors
0 io errors, 742 checksum errors
Thin device 2 has 81 errors and is missing 86964 mappings, while expected 135410
Thin device 5 has 31 errors and is missing 6289 mappings, while expected 68360
Thin device 7 has 255+ errors and is missing 53080 mappings, while expected 130056
Thin device 8 has 103 errors and is missing 19837 mappings, while expected 32781
Thin device 9 has 71 errors and is missing 14386 mappings, while expected 17997
Thin device 10 has 108 errors and is missing 45454 mappings, while expected 62684
Thin device 12 has 68 errors and is missing 38761 mappings, while expected 99297
Check of mappings failed

Do you get consistent outputs from thin_check across different runs?

thin_check gives the same output every time for me.

There is no verbose option for thin_metadata_pack, I don't think, but I get:

"Input/output error (os error 5)".

This is the error that for me is non-deterministic, in that sometimes the error raises quickly, and other times after a much longer time.

thin_metadata_pack runs in buffered io. The errors in packed metadata might come from short reads when reading series of blocks. Maybe you could check the error counter from thin_check's logs (# io errors, # checksum errors), and stracing thin_check as well.