/ dev / sda1:破損した孤立リンクリストの一部であったiノードが見つかりました


16

突然、ハードドライブが読み取り専用になったとき、Ubuntu 2015.04(ecryptfsで暗号化されたユーザーホーム)ラップトップを通常使用していました。

私は再起動し、今ではこれで立ち往生しています:

[    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:~#

システムログの興味深い部分:

-- 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

ACPIの問題なのか、ディスクの問題なのかわかりません。Lenovo Thinkpad T520を最新のBIOSにアップデートしようとしましたが、起動しません。

この問題を解決する方法、またはディスクが暗号化された家から外部ドライブに少なくともデータをエクスポートする方法が死んでいる場合はどうなりますか?


8
ルートファイルシステムでエラーが見つかりました。指示どおりに実行しfsck /dev/sda1、検出したエラーを対話形式で表示し、修正することを選択します。何度もノーと言って、エラーの数を確認してください。ログファイルのように、重要性のないファイルのみのように見える場合は、もう一度「はい」と言います。これにより、ファイルが失われる可能性があるため、最初にパーティションをコピーしてusbデバイスと言うことができる場合は、最初にコピーしてください。
-meuh

回答:


19
  1. プロンプトで、fsck /dev/sda<number>入力してEnterキーを押します(<number>ファイルシステムエラーを含むディレクトリに基づいてログから検索します)
  2. yすべてのエラーを入力して修正します
  3. exit

<番号>を見つける方法
カピルヤダブ

Tyvm。動いた。
ビラス

1
@KapilYadav:スローされるエラーログで番号を見つけることができます。たとえば、OPの質問では、ログにはsystem-fsck[475]: /dev/sda1 contains a file system with errors, check forced.「番号は1
ロッキーインデ

0

ターミナル内

sudo -i (rootユーザーでない場合は、スキップします)

fdisk -l

ルートドライブを探します。

私はラズベリーパイでKali Linuxを使用しているので、私のmmcblk0p2代わりにsdb1...のように見えます。

`umount /dev/mmcblk0p2`

fsck -y /dev/mmcblk0p2

poweroff


-1

同じ問題が発生しました。Win32DiskImagerを使用して、動作中のRaspbian SDCardから画像ファイルを作成しました。pishrinkを実行すると、このツールから「孤立したiノードリスト」エラーが表示されました。そこで、Rocky Indeからの提案に従ってfsckを実行しました。それはいくつかのエラーに遭遇して修正したので、私は再びpishrinkを走らせて、それはうまくいきました!ありがとう、ロック・インデ。

ここまで来て、それを行う方法がまだ分からない場合は、これらの「孤立したiノード」を修正するために、部分的にピシュリンクに基づいたスクリプトを作成しました。スクリプトソースは次の場所で確認できます。

https://github.com/gmenezesg/fix_orphaned_inode_list

使用法:

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]

脚本:

#!/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"
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.