So verwenden Sie den nohup-Befehl unter Linux

Veröffentlicht: 2022-06-25
Linux-Laptop mit einer Bash-Eingabeaufforderung
fatmawati achmad zaenuri/Shutterstock.com

Der Linux-Befehl nohup lässt wichtige Prozesse auch dann weiterlaufen, wenn das Terminalfenster, das sie gestartet hat, geschlossen ist. Wir zeigen Ihnen, wie Sie diesen ehrwürdigen Befehl auf dem heutigen Linux verwenden.

HUP und SIGHUP

Unix, der Vorfahre von Linux, wurde entwickelt, bevor der PC erfunden wurde. Computer waren große, teure Geräte. Die Benutzer interagierten mit ihnen über serielle Leitungen entweder lokal innerhalb desselben Gebäudes oder aus der Ferne über langsame Modemverbindungen. Ursprünglich tippten sie ihre Anweisungen auf Fernschreibern, die nach und nach durch dumme Terminals ersetzt wurden.

Sie wurden dumm genannt, weil die Rechenleistung in dem Computer lag, mit dem Sie verbunden waren, und nicht in dem Terminal, auf dem Sie tippten. Die Programme liefen auf dem Computer – wo auch immer sich dieser befunden haben mag – und nicht auf dem Gerät auf Ihrem Schreibtisch.

Wenn etwas passiert ist, das die Verbindung zwischen Ihrem Terminal und dem Computer unterbrochen hat, hat der Computer den Leitungsausfall erkannt und ein HUP oder Auflegesignal an die von Ihnen ausgeführten Programme gesendet. Die Programme beendeten die Ausführung, als sie das Signal empfingen.

So beenden Sie eine Desktop-Anwendung oder einen Hintergrundprozess unter Linux
RELATED So beenden Sie eine Desktop-Anwendung oder einen Hintergrundprozess unter Linux

Diese Funktionalität lebt heute in Linux weiter. Auf Ihrem PC ist ein Terminalfenster eine Emulation eines physischen Terminals. Wenn Sie Prozesse ausführen, die von diesem Terminalfenster aus gestartet wurden, und Sie schließen dieses Fenster, wird das SIGHUP -Signal an die Programme gesendet, damit sie über das HUP informiert werden und wissen, dass sie beendet werden sollen.

Es findet ein Kaskadeneffekt statt. Wenn die Prozesse untergeordnete Prozesse gestartet haben, wird das SIGHUP auch an sie weitergegeben, damit sie wissen, dass sie terminieren sollten.

Der Befehl nohup startet untergeordnete Prozesse, weigert sich jedoch, SIGHUP Signale an sie weiterzuleiten. Das mag nach einem Problem klingen, ist aber tatsächlich eine nützliche Funktion.

Der Nohup-Befehl

Wenn Sie möchten, dass ein Prozess fortgesetzt wird, auch wenn das Terminalfenster, von dem er gestartet wurde, geschlossen ist, müssen Sie das SIGHUP abfangen, damit das Programm es nie empfängt. (Eigentlich startet das Terminalfenster keine Prozesse, sie werden von der Shell-Sitzung im Terminalfenster gestartet.) Die einfache und elegante Lösung für dieses Problem besteht darin, einen anderen Prozess zwischen der Shell-Sitzung und dem Programm zu platzieren und das zu haben Middle-Layer-Programme geben das SIGHUP -Signal niemals weiter.

Das macht nohup . Es startet Programme für Sie, sodass sie ein untergeordneter Prozess von nohup sind, kein untergeordneter Prozess der Shell. Da sie kein untergeordneter Prozess der Shell sind, erhalten sie kein SIGHUP direkt von der Shell. Und wenn nohup das SIGHUP nicht an seine Kinder weitergibt, erhält das Programm überhaupt kein SIGHUP .

Dies ist beispielsweise nützlich, wenn Sie einen lang andauernden Prozess haben, den Sie vollständig ablaufen lassen müssen. Wenn Sie versehentlich das Terminalfenster und seine Shell schließen, beenden Sie auch den Prozess. Die Verwendung von nohup zum Starten des Prozesses isoliert den Prozess vom nohup -Signal. Wenn Sie remote auf einem Computer über SSH arbeiten und nicht möchten, dass ein sensibler Prozess beendet wird, wenn die Remoteverbindung fehlschlägt, starten Sie den Prozess auf dem Remotecomputer mit nohup .

Mit nohup

Wir haben ein Programm erstellt, das nichts Nützliches tut, aber es läuft und läuft, bis es beendet wird. Es gibt alle drei Sekunden die Zeit im Terminalfenster aus. Es heißt long-proc für „langer Prozess“.

 ./long-proc 

Das Long-Proc-Programm, das ein Terminalfenster ausführt

Wenn dies ein Programm wäre, das etwas Nützliches getan hat und wir wollten, dass es auch dann weiterläuft, wenn das Terminalfenster und die Shell geschlossen sind, würden wir es mit nohup starten.

 nohup ./long-proc 

Starten des Long-Proc-Programms von nohup

Der Prozess ist von stdin und stdout entkoppelt, sodass er weder Eingaben empfangen noch in das Terminalfenster schreiben kann. Da es noch ausgeführt wird, kehren Sie außerdem nicht zur Eingabeaufforderung zurück. Alles, was nohup tut, ist, den Prozess unempfindlich gegen das Schließen des Terminals zu machen. Es verwandelt den Prozess nicht in eine Hintergrundaufgabe.

Müssen Sie jetzt neu starten, um den Vorgang zu beenden? Nein. Um einen nohup -Prozess zu stoppen, den Sie nicht als Hintergrundprozess gestartet haben, drücken Sie die Tastenkombination Strg+C.

Anhalten des Long-Proc-Prozesses mit Strg+C

Die Ausgabe des Programms wurde für uns in einer Datei namens „nohup.out“ festgehalten. Wir können es mit weniger überprüfen.

 weniger nohup.out 

Öffnen der nohup.out-Datei in weniger

Alles, was normalerweise an das Terminalfenster gesendet wird, wird in der Datei erfasst. Nachfolgende Ausführungen von nohup werden an die vorhandene Datei „nohup.out“ angehängt.

Die Ausgabe von long-proc, geschrieben in die Datei nohup.out, angezeigt in less

Eine nützlichere Möglichkeit, den Prozess auszuführen, besteht darin, ihn mit nohup zu starten, damit er dem Schließen des Terminalfensters standhält, und ihn gleichzeitig zu einer Hintergrundaufgabe zu machen. Dazu fügen wir am Ende der Befehlszeile ein kaufmännisches Und „ & “ hinzu.

 nohup ./long-proc & 

Starten Sie das Programm mit langer Prozedur mit nohup und machen Sie es zu einer Hintergrundaufgabe

Sie müssen erneut „Enter“ drücken, um zur Eingabeaufforderung zurückzukehren. Uns wird mitgeteilt, dass die Jobnummer des Prozesses 1 ist – die Zahl in Klammern „ [] “ – und dass die Prozess-ID 13115 ist.

Wir können beide verwenden, um den Prozess zu beenden. „Strg+C“ funktioniert jetzt nicht, da das Programm weder mit dem Terminalfenster noch mit der Shell verbunden ist.

Wenn Sie die Jobnummer vergessen haben, können Sie den Befehl jobs verwenden, um die Hintergrundaufgaben aufzulisten, die von diesem Terminalfenster aus gestartet wurden.

 Arbeitsplätze 

Auflisten der Hintergrundaufgaben, die von einem Terminalfenster aus gestartet wurden

Um unsere Aufgabe zu beenden, können wir den kill Befehl und die Jobnummer verwenden, denen ein Prozentzeichen „ % “ vorangestellt ist, wie folgt:

 töte %1

Wenn Sie das Terminalfenster geschlossen haben, müssen Sie die Prozess-ID finden und diese mit dem kill Befehl verwenden. Der Befehl pgrep findet die Prozess-ID für Prozesse, die mit dem von Ihnen angegebenen Suchhinweis übereinstimmen. Wir suchen nach dem Prozessnamen.

 pgrep long-proc 

Suchen der Prozess-ID eines Prozesses anhand des Namens

Jetzt können wir die Prozess-ID verwenden, um den Prozess zu beenden.

 töte 13115 

Verwenden des Kill-Befehls und der Prozess-ID zum Beenden eines Prozesses

Wenn Sie das nächste Mal „Enter“ drücken, werden Sie darüber informiert, dass der Vorgang beendet wurde.

Schauen wir uns nun an, was den Prozess nicht beendet. Wir starten es neu und schließen dann das Terminalfenster.

 nohup ./long-proc 

Schließen des Terminalfensters bei laufendem Prozess

Wenn wir ein neues Terminalfenster öffnen und mit pgrep nach unserem Prozess suchen, sehen wir, dass er noch läuft. Das Schließen des Terminalfensters, das den Prozess gestartet hat, hat keine Wirkung gehabt.

 pgrep long-proc 

Mit pgrep nach einem Prozess nach Namen suchen

Es ist möglich, mehrere Befehle an nohup zu übergeben, aber es ist normalerweise besser, sie separat zu starten. Es macht es einfacher, sie als Hintergrundjobs zu manipulieren. Die Befehle werden nicht gleichzeitig ausgeführt, sie werden nacheinander ausgeführt. Die Ausführung erfolgt nicht gleichzeitig, sondern sequentiell. Damit sie gleichzeitig ausgeführt werden, müssen Sie sie separat starten.

Um jedoch mehrere Prozesse gleichzeitig zu starten, verwenden nohup , um eine Bash-Shell zu starten, und verwenden Sie die Option -c (Befehle) mit der Befehlsfolge. Verwenden Sie einfache Anführungszeichen „ ' “, um die Befehlsliste einzuschließen, und doppelte kaufmännische Und-Zeichen „ && “, um die Befehle zu trennen.

 nohup bash -c 'ls /bin && ls /sbin' 

Starten von zwei Prozessen mit nohup

Wenn Sie less verwenden, um die Datei „nohup.out“ zu durchsuchen, sehen Sie die Ausgabe des ersten Prozesses und dann die Ausgabe des zweiten Prozesses.

 weniger nohup.out 

Öffnen der nohup.out-Datei in weniger

Die Ausgabe beider Befehle wurde in der Datei „nohup.out“ erfasst. Es ist nicht verflochten, die Ausgabe des zweiten Prozesses beginnt erst, wenn der erste Prozess beendet ist.

Der Inhalt der Datei nohup.out in less

Wenn Sie anstelle von „nohup.out“ eine eigene Datei verwenden möchten, können Sie den Befehl in die Datei Ihrer Wahl umleiten.

 nohup bash -c 'ls /bin && ls /sbin' > meinedatei.txt 

Umleiten der Ausgabe von den Prozessen in eine vom Benutzer bereitgestellte Datei

Beachten Sie, dass in der Meldung nicht mehr „Ausgabe an nohupo.out anhängen“ steht, sondern „stderr auf stdout umgeleitet wird“ und wir stdout in unsere Datei „myfile.txt“ umleiten.

Wir können mit weniger in die Datei „myfile.txt“ schauen.

 weniger meinedatei.txt 

Wie zuvor enthält es die Ausgabe beider Befehle.


Es ist komisch, wie die Geschichte eines Versorgungsunternehmens manchmal den Anschein erwecken kann, als hätte es keine Relevanz für die moderne Zeit. Der Befehl nohup ist einer davon. Etwas, das geschaffen wurde, um mit Verbindungsabbrüchen auf seriellen Leitungen fertig zu werden, ist für die heutigen Linux-Benutzer auf unglaublich leistungsfähigen Rechnern immer noch nützlich.

VERWANDT: 37 Wichtige Linux-Befehle, die Sie kennen sollten