Bootprobleme einer Linux-VM aufgrund von fstab-Fehlern beheben


Fstab (Dateisystemtabelle) ist eine Konfigurationsdatei, mit der Sie definieren, wie die Laufwerkspartition, das Dateisystem und die Dateifreigabenbereitstellungen in Ihrer Linux-VM bei einem Systemneustart beibehalten werden.

In diesem Dokument werden mehrere Bedingungen beschrieben, unter denen eine falsche fstab-Konfiguration zu einem Boot-Problem führen kann. Außerdem finden Sie hier Tipps zur Fehlerbehebung.

Im Folgenden sind einige häufige Probleme mit der Fehlkonfiguration von fstab aufgeführt:

  • Syntaxfehler in der Konfigurationsdatei fstab
  • Eine falsche UUID
  • Es gibt einen Eintrag für ein nicht angeschlossenes/nicht verfügbares Gerät.
  • Eingestellte Bereitstellungsoptionen wie nobarrier für das XFS-Dateisystem in SUSE- oder RHEL-Images.

Vorbereitung

  • Wenn Sie Cloud Logging zum Logging der Ausgabe des seriellen Ports verwenden möchten, machen Sie sich mit Cloud Logging vertraut.
  • Richten Sie die Authentifizierung ein, falls Sie dies noch nicht getan haben. Bei der Authentifizierung wird Ihre Identität für den Zugriff auf Google Cloud Dienste und APIs überprüft. Zur Ausführung von Code oder Beispielen aus einer lokalen Entwicklungsumgebung können Sie sich bei Compute Engine authentifizieren. Wählen Sie dazu eine der folgenden Optionen aus:

    Select the tab for how you plan to use the samples on this page:

    Console

    When you use the Google Cloud console to access Google Cloud services and APIs, you don't need to set up authentication.

    gcloud

    1. Install the Google Cloud CLI, then initialize it by running the following command:

      gcloud init
    2. Set a default region and zone.
    3. REST

      Verwenden Sie die von der gcloud CLI bereitgestellten Anmeldedaten, um die REST API-Beispiele auf dieser Seite in einer lokalen Entwicklungsumgebung zu verwenden.

        Install the Google Cloud CLI, then initialize it by running the following command:

        gcloud init

      Weitere Informationen finden Sie unter Für die Verwendung von REST authentifizieren in der Dokumentation zur Google Cloud-Authentifizierung.

fstab-Probleme identifizieren

Bei Bootproblemen empfiehlt Google dringend, die Boot-Logs in der seriellen Konsole der Linux-VM zu prüfen. Die VM wechselt in den Notfallmodus und es wird eine Fehlermeldung angezeigt, die darauf hinweist, dass das Problem mit fstab zusammenhängt.

  [K[[1;31m TIME [0m] Timed out waiting for device dev-incorrect.device.
  [[1;33mDEPEND[0m] Dependency failed for /distribution.
  [[1;33mDEPEND[0m] Dependency failed for Local File Systems.
  ...
  Welcome to emergency mode! After logging in, type "journalctl -xb" to viewsystem logs, "systemctl reboot" to reboot, "systemctl default" to try again to boot into default mode.
  Give root password for maintenance
  (or type Control-D to continue)
  

Laut Fehlermeldung ist ein Abhängigkeitsfehler für das /distribution-Dateisystem aufgetreten. Der Abhängigkeitsfehler für einen Dateisystem-Bereitstellungspunkt unterscheidet sich je nach verwendeten Dateisystemnamen.

Lösung

Mit den folgenden Optionen können Sie den fstab-Fehler in Linux-VMs beheben, die in Google Cloudgehostet werden. Mit der seriellen Konsole können Sie das Problem schneller beheben als mit der manuellen Methode.

Wenn Sie das fstab-Problem mit den folgenden Methoden beheben möchten, müssen Sie den Zugriff auf den seriellen Port für Ihre VM aktivieren.

Option 1: Mit der seriellen Konsole im Notfall-Modus in der VM anmelden

  1. Melden Sie sich über die Google Cloud Console in der seriellen Konsole der VM an. Serielle Konsole

  2. Geben Sie im aktuellen Notfallmodus das Root-Passwort ein, um auf Ihre VM zuzugreifen.

  3. Öffnen Sie die Datei fstab mit Ihrem bevorzugten Texteditor. Nehmen Sie die erforderlichen Änderungen vor und speichern Sie sie in der Datei fstab. Im folgenden Beispiel wird der Editor vi verwendet.

    vi /etc/fstab

    Fstab-Datei

    Im vorherigen Beispiel ist das Gerät für /distribution von der VM getrennt. Kommentieren Sie die Zeile, die auf das Dateisystem verweist, oder entfernen Sie den fstab-Eintrag für den Bereitstellungspunkt /distribution.

    Verwenden Sie man fstab für Weitere Informationen zur Konfiguration und Syntax von fstab.

  4. Speichern Sie die Datei und beenden Sie den Editor. Wenn Sie den vi-Editor verwenden, verwenden Sie ESC + :wq!, um zu speichern und den Editor zu beenden.

  5. Setzen Sie den Bootvorgang fort, indem Sie bei der Eingabeaufforderung reboot eingeben.

  6. Nachdem das Problem erfolgreich behoben wurde, sollte der Bootvorgang der VM abschließen und die Anmeldeaufforderung wird in der seriellen Konsole angezeigt.

  7. Prüfen Sie, ob Sie sich wieder über SSH bei der VM anmelden können.

Option 2: Modus „Einzelner Nutzer“ in der seriellen Konsole verwenden

Diese Option kann verwendet werden, wenn das Root-Passwort nicht festgelegt ist.

Voraussetzung: Der Parameter GRUB_TIMEOUT in der grub-Konfigurationsdatei muss auf einen Wert ungleich null festgelegt sein. Im Allgemeinen ist diese Datei unter /etc/default/grub gespeichert. Bei einigen älteren Distributionen kann sie jedoch in einem nicht standardmäßigen Verzeichnis gespeichert sein.

  1. Rufen Sie in der Google Cloud Console die Seite „VM-Instanzen” auf. Zur Seite „VM-Instanzen“

  2. Melden Sie sich über die Google Cloud Console in der seriellen Konsole der virtuellen Maschine an. Serielle Konsole2

  3. Klicken Sie in der Google Cloud Console auf ZURÜCKSETZEN für die virtuelle Maschine.

    Datei zurücksetzen

  4. Unterbrechen Sie im Fenster der seriellen Konsole den Bootvorgang, indem Sie im grub-bildschirm oder im Menü auf den Pfeil klicken, um zu pausieren.

  5. Wählen Sie in der Liste der Kernel auf dem Bildschirm des Grub-Bootloaders den Kernel aus und drücken Sie auf der Tastatur die Taste e.

    Bootloaderdatei

  6. Fügen Sie den Parameter rd.break am Ende der Kernelzeile hinzu und drücken Sie ctrl + x. Dadurch wird die VM im Einzelnutzermodus gestartet.

    Bootloader-Menü

  7. Das Stammdateisystem im Lese-/Schreibmodus bereitstellen

  8. Analysieren Sie die Datei fstab, nehmen Sie die erforderlichen Änderungen vor und speichern Sie sie. Verwenden Sie man fstab für weitere Informationen zur Konfiguration und Syntax. Öffnen Sie die Datei fstab mit Ihrem bevorzugten Texteditor. Im folgenden Beispiel wird der vi-Editor verwendet.

    vi /etc/fstab

    Fstab-Datei2

    In diesem Beispiel ist das Gerät für /distribution von der VM getrennt. Kommentieren Sie daher die Zeile oder entfernen Sie den fstab-Eintrag für den Bereitstellungspunkt /distribution.

  9. Speichern Sie die Datei und beenden Sie den Editor. Wenn Sie den vi-Editor verwenden, speichern Sie mit ESC + :wq! und verlassen Sie damit fstab.

  10. Setzen Sie den Bootvorgang fort, indem Sie bei der Eingabeaufforderung reboot eingeben.

  11. Nachdem das Problem erfolgreich behoben wurde, sollte der Bootvorgang der VM abschließen und die Anmeldeaufforderung wird in der seriellen Konsole angezeigt.

  12. Prüfen Sie, ob Sie sich über SSH bei der VM anmelden können.

Option 3: VM wiederherstellen

Diese Option kann verwendet werden, wenn das Root-Passwort nicht festgelegt ist oder Sie den Einzelnutzermodus nicht verwenden können.

Weitere Informationen finden Sie unter Unzugängliche VM wiederherstellen.