/ dev / sda1: Znaleziono i-węzły, które były częścią uszkodzonej osieroconej listy połączonej

16

Zwykle korzystałem z laptopa Ubuntu 2015.04 (z zaszyfrowanym ecryptfs home home), gdy nagle dysk twardy stał się tylko do odczytu.

Uruchomiłem ponownie i teraz utknęło w tym:

[    0.703206] ACPI PCC probe failed.
starting version 219
error: /dev/sdb: No medium found
error: /dev/sdb: No medium found
Welcome to emergency mode! After logging in, type "journalctl -xb" to view
system logs, "systemctl reboot" to reboot, "systemctl default or ^D to
try again to boot into default mode.
root@nico:~#

Interesująca część dzienników systemu:

-- Unit systemd-fsckd.service has begun starting up.
system-fsck[475]: /dev/sda1 contains a file system with errors, check forced.
kernel: ACPI warning: \_SB_.PCIO.PEG_.VID_._DSM: Argument #4 type mismatch - Found [Buffer], ACPI requires [Package] (20141107/nsarguments-95)
kernel: ACPI warning: \_SB_.PCIO.PEG_.VID_._DSM: Argument #4 type mismatch - Found [Buffer], ACPI requires [Package] (20141107/nsarguments-95)
kernel: thinkpad_acpi: EC reports that Thermal Table has changed
system-fsck[475]: /dev/sda1: Inodes that were part of a corrupted orphan linked list found.
system-fsck[475]: /dev/sda1: UNEXPECTED INCONSISTENCY; RUN fsck MANUALLY.
system-fsck[475]: (i.e., without -a or -p options)
system-fsck[475]: fsck failed with error code 4.
system-fsck[475]: Running request emergency.target/start/replace
systemd[1]: system-fsck-root.service: main process exited, code=exited, status=1/FAILURE
systemd[1]: Failed to start File System Check on Root Device
-- Subject: Unit system-fsck-root.service has failed

Nie jestem pewien, czy jest to problem ACPI, czy problem z dyskiem. Próbowałem zaktualizować system BIOS do najnowszej wersji Lenovo Thinkpad T520, ale nie można go uruchomić lepiej.

Jak rozwiązać ten problem lub jeśli dysk umiera, jak przynajmniej wyeksportować dane z mojego zaszyfrowanego domu na dysk zewnętrzny?

Nicolas Raoul
źródło
8
znalazł błędy w głównym systemie plików. rób tak, jak mówi, uruchamiaj fsck /dev/sda1i interaktywnie pozwól, aby pokazywał znalezione błędy, i wybierz ich poprawienie. Przejdź raz raz odmawiając cały czas, aby zobaczyć, ile błędów jest. Jeśli wydają się dotyczyć tylko plików nieistotnych, takich jak pliki dziennika, przejdź ponownie i powiedz „tak”. może to spowodować utratę plików, więc jeśli możesz najpierw skopiować partycję, aby powiedzieć urządzenie USB, zrób to najpierw.
meuh,

Odpowiedzi:

20
  1. Po wyświetleniu monitu wpisz fsck /dev/sda<number>i naciśnij klawisz Enter (wyszukaj w <number>dziennikach na podstawie katalogu zawierającego błędy systemu plików)
  2. Wprowadź ywszystkie błędy, aby je naprawić
  3. exit
Rocky Inde
źródło
jak znaleźć <liczba>
Kapil Yadav
Tyvm. Zadziałało.
Viraths
1
@KapilYadav: liczbę można znaleźć w dziennikach błędów, które zostaną wyrzucone. Na przykład, w pytaniu OP dziennik mówi: system-fsck[475]: /dev/sda1 contains a file system with errors, check forced.Stąd liczba to1
Rocky Inde
0

W terminalu

sudo -i (jeśli nie jest użytkownikiem root, w przeciwnym razie pomiń to)

fdisk -l

Poszukaj swojego dysku głównego.

Używam Kali Linux w Raspberry Pi, więc mój wygląda jak mmcblk0p2zamiast sdb1... Sprawdź swoje.

`umount /dev/mmcblk0p2`

fsck -y /dev/mmcblk0p2

poweroff

insidevoid
źródło
-1

Miałem ten sam problem. Utworzyłem plik obrazu z działającej karty Raspbian SDCard przy użyciu Win32DiskImager. Kiedy uruchomiłem pishrink, narzędzie zwróciło mi błąd „osieroconej listy i-węzłów”. Więc zastosowałem się do sugestii Rocky Inde i wykonałem fsck. Napotkał i naprawił kilka błędów, więc ponownie uruchomiłem pishrink i zadziałało! Dzięki Rock Inde.

Jeśli dotarłeś tak daleko i nadal nie wiesz, jak to zrobić, stworzyłem skrypt, częściowo oparty na pishrink, aby naprawić te „osierocone i-węzły”. Możesz sprawdzić źródło skryptu pod adresem

https://github.com/gmenezesg/fix_orphaned_inode_list

Stosowanie:

wget https://raw.githubusercontent.com/gmenezesg/fix_orphaned_inode_list/master/fix_orphaned_inode_list.sh

sudo chmod +x fix_orphaned_inode_list.sh

sudo ./fix_orphaned_inode_list.sh [imagefile.img]

Scenariusz:

#!/bin/bash

function cleanup() {
  if losetup $loopback &>/dev/null; then
        if [ "$verbose_mode" = true ]; then
        echo "### Running cleanup ###"
        fi
        losetup -d "$loopback"
  fi
}

verbose_mode=false

while getopts ":v" opt; do
  case "${opt}" in
    v) verbose_mode=true ;;
    *) usage ;;
  esac
done
shift $((OPTIND-1))

usage() { echo "Usage: $0 [-v] imagefile.img"; exit -1; }

if [ "$verbose_mode" = true ]; then
echo "### Mapping arguments ###"
fi

img="$1"

if [ "$verbose_mode" = true ]; then
echo "### Usage checks ###"
fi

if [[ -z "$img" ]]; then
  usage
fi
if [[ ! -f "$img" ]]; then
  echo "ERROR: $img is not a file..."
  exit -2
fi
if (( EUID != 0 )); then
  echo "ERROR: You need to be running as root."
  exit -3
fi

echo "#Check that what we need is installed"
for command in parted losetup tune2fs md5sum e2fsck resize2fs; do
  which $command 2>&1 >/dev/null
  if (( $? != 0 )); then
    echo "ERROR: $command is not installed."
    exit -4
  fi
done

if [ "$verbose_mode" = true ]; then
echo "### Setting cleanup at script exit ###"
fi
trap cleanup ERR EXIT

beforesize=$(ls -lh "$img" | cut -d ' ' -f 5)
parted_output=$(parted -ms "$img" unit B print | tail -n 1)
partnum=$(echo "$parted_output" | cut -d ':' -f 1)
partstart=$(echo "$parted_output" | cut -d ':' -f 2 | tr -d 'B')
loopback=$(losetup -f --show -o $partstart "$img")
tune2fs_output=$(tune2fs -l "$loopback")
currentsize=$(echo "$tune2fs_output" | grep '^Block count:' | tr -d ' ' | cut -d ':' -f 2)
blocksize=$(echo "$tune2fs_output" | grep '^Block size:' | tr -d ' ' | cut -d ':' -f 2)

fsck -y "$loopback"
użytkownik408841
źródło