So verwenden Sie den nohup-Befehl unter Linux
Veröffentlicht: 2022-06-25 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.
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
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
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.
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
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.
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 &
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
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
Jetzt können wir die Prozess-ID verwenden, um den Prozess zu beenden.
töte 13115
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
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
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'
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
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.
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
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