Após a execução btrfs scrub
, os arquivos corrompidos podem ser detectados. Para determinar os arquivos incorrigíveis, podemos tentar ler todos os arquivos no disco:
sudo find / -type f -exec cp -v {} /dev/null \; 2> corrupted-files.txt
A saída deste comando satisfaz a necessidade. No entanto, leva horas para ser concluído.
O wiki do Arch Linux sugere o seguinte comando para determinar os arquivos corrompidos:
sudo journalctl --output cat | grep 'BTRFS .* i/o error' | sort | uniq
Ele busca resultados rapidamente. No entanto, os caminhos dos arquivos são relativos aos seus caminhos de subvolume, portanto, inestimáveis para corrigir os arquivos dos backups:
BTRFS warning (device dm-2): i/o error at logical 69945753600 on dev /dev/mapper/zeytin-root, sector 142920640, root 636, inode 172280, offset 238682112, length 4096, links 1 (path: home/aea/couchdb/couchdb/data/shards/60000000-7fffffff/client2.1533443496.couch)
BTRFS warning (device dm-2): i/o error at logical 70045958144 on dev /dev/mapper/zeytin-root, sector 143116352, root 422, inode 172296, offset 307662848, length 4096, links 1 (path: home/aea/couchdb/couchdb/data/shards/e0000000-ffffffff/client2.1533443496.couch)
BTRFS warning (device dm-2): i/o error at logical 70045958144 on dev /dev/mapper/zeytin-root, sector 143116352, root 636, inode 172296, offset 307662848, length 4096, links 1 (path: home/aea/couchdb/couchdb/data/shards/e0000000-ffffffff/client2.1533443496.couch)
BTRFS warning (device dm-2): i/o error at logical 70138376192 on dev /dev/mapper/zeytin-root, sector 143296856, root 423, inode 100548, offset 688631808, length 4096, links 1 (path: var/log/auth.log)
BTRFS warning (device dm-2): i/o error at logical 70138425344 on dev /dev/mapper/zeytin-root, sector 143296952, root 423, inode 100548, offset 688644096, length 4096, links 1 (path: var/log/auth.log)
BTRFS warning (device dm-2): i/o error at logical 70138441728 on dev /dev/mapper/zeytin-root, sector 143296984, root 423, inode 100548, offset 688648192, length 4096, links 1 (path: var/log/auth.log)
BTRFS warning (device dm-2): i/o error at logical 70138449920 on dev /dev/mapper/zeytin-root, sector 143297000, root 419, inode 818783, offset 95145984, length 4096, links 1 (path: var/log/daemon.log)
BTRFS warning (device dm-2): i/o error at logical 70138564608 on dev /dev/mapper/zeytin-root, sector 143297224, root 419, inode 818783, offset 95154176, length 4096, links 1 (path: var/log/daemon.log)
BTRFS warning (device dm-2): i/o error at logical 70138884096 on dev /dev/mapper/zeytin-root, sector 143297848, root 419, inode 818783, offset 95174656, length 4096, links 1 (path: var/log/daemon.log)
Existe uma maneira de determinar o caminho do subvolume usando o sector XXXXXXX, root XXX, inode XXXXXXX, offset XXXXXXXX
valor?
Aqui o
root XXX
valor é o ID raiz do subvolume. Assim, o caminho do subvolume correspondente pode ser determinado por:O script útil que faz a junção interna é o seguinte:
Resultado:
Assim, a ferramenta geral get-corrupted-files.sh se torna: