


Wie führe ich einen lang laufenden Prozess in Go aus und trenne ihn vom übergeordneten Prozess?
Einen Befehl in Go ausführen und vom Prozess trennen
Problem
Ich muss einen lang andauernden Prozess in Go ausführen und dabei das erfüllen Folgende Anforderungen:
- Standardausgabe des Prozesses in eine Datei umleiten.
- Kontrollieren Sie den Benutzer des Prozesses.
- Stellen Sie sicher, dass der Prozess fortgesetzt wird, nachdem mein Programm beendet wurde.
- Verhindern Sie, dass der Prozess zu einem Zombie wird, wenn er abstürzt.
- Erhalten Sie die PID des laufenden Prozesses.
Ich führe mein Programm mit Root-Berechtigungen aus und habe Ich habe versucht, eine Lösung mit exec.Command() und syscall.SysProcAttr zu finden, aber sie schlägt fehl, wenn ich SIGTERM/SIGKILL an mein Programm sende, was zum Absturz des zugrunde liegenden Prozesses führt. Ich möchte den Prozess als Daemon ausführen, getrennt von der Steuerung meines Programms.
Lösung
Die Verwendung einer externen Bibliothek wie github.com/hashicorp/go-reap wird dringend empfohlen Es löst das Problem effektiv. Wenn Sie jedoch eine benutzerdefinierte Implementierung bevorzugen, kann der folgende Ansatz in Betracht gezogen werden:
- Standardausgabe umleiten: Verwenden Sie cmd.Stdout = stdLogFile, um die Standardausgabe des Prozesses in eine angegebene Datei umzuleiten .
- Benutzer steuern: Legen Sie cmd.SysProcAttr = &syscall.SysProcAttr{Credential: &syscall.Credential{Uid: uid}} fest, um den Benutzer des Prozesses zu steuern.
- Vom Prozess trennen: Führen Sie den Befehl in einer separaten Goroutine mit go func() { cmd.Wait() }() aus, um zu verhindern, dass er zu einem Zombie wird.
- PID abrufen: Verwenden Sie cmd.Process.Pid, um die PID des laufenden Prozesses abzurufen.
Hinweis
Es ist wichtig zu erkennen, dass es unmöglich ist, den Prozess vollständig zu trennen übergeordnete und untergeordnete Prozesse im Hinblick auf die Prozessvererbung. Alle Prozesse müssen ein übergeordnetes Element haben. Wenn das übergeordnete Element stirbt, wird das untergeordnete Element zu einer Waise und wird von PID 1 (init) adoptiert. Mit anderen Worten: Das untergeordnete Element kann keinen anderen übergeordneten Prozess haben als den ursprünglichen Prozess, der es gestartet hat.
Um sicherzustellen, dass der Prozess nach dem Beenden des übergeordneten Prozesses weiter ausgeführt wird, sollten Sie die Verwendung eines dedizierten Prozessmanagers wie systemd oder docker in Betracht ziehen, der dies verwalten kann verwaiste Prozesse und stellen deren weitere Ausführung sicher. Andere mögliche Lösungen umfassen das Schreiben eines benutzerdefinierten Daemons oder die Verwendung einer Bibliothek wie go-daemon, um den Lebenszyklus des Prozesses unabhängig vom übergeordneten Programm zu verwalten.
Das obige ist der detaillierte Inhalt vonWie führe ich einen lang laufenden Prozess in Go aus und trenne ihn vom übergeordneten Prozess?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen











Golang ist in Bezug auf Leistung und Skalierbarkeit besser als Python. 1) Golangs Kompilierungseigenschaften und effizientes Parallelitätsmodell machen es in hohen Parallelitätsszenarien gut ab. 2) Python wird als interpretierte Sprache langsam ausgeführt, kann aber die Leistung durch Tools wie Cython optimieren.

Golang ist in Gleichzeitigkeit besser als C, während C bei Rohgeschwindigkeit besser als Golang ist. 1) Golang erreicht durch Goroutine und Kanal eine effiziente Parallelität, die zum Umgang mit einer großen Anzahl von gleichzeitigen Aufgaben geeignet ist. 2) C über Compiler -Optimierung und Standardbibliothek bietet es eine hohe Leistung in der Nähe der Hardware, die für Anwendungen geeignet ist, die eine extreme Optimierung erfordern.

GoisidealforBeginersandSuitableforCloudandNetWorkServicesDuetoitsSimplicity, Effizienz und Konsumfeaturen.1) InstallgoFromTheofficialwebSiteAnDverifyWith'goversion'.2) CreateAneDrunyourFirstProgramwith'gorunhello.go.go.go.

Golang ist für schnelle Entwicklung und gleichzeitige Szenarien geeignet, und C ist für Szenarien geeignet, in denen extreme Leistung und Kontrolle auf niedriger Ebene erforderlich sind. 1) Golang verbessert die Leistung durch Müllsammlung und Parallelitätsmechanismen und eignet sich für die Entwicklung von Webdiensten mit hoher Konsequenz. 2) C erreicht die endgültige Leistung durch das manuelle Speicherverwaltung und die Compiler -Optimierung und eignet sich für eingebettete Systementwicklung.

GoimpactsDevelopmentPositivyThroughSpeed, Effizienz und DiasMlitication.1) Geschwindigkeit: Gocompilesquickandrunseffiction, idealforlargeProjects

Golang und Python haben jeweils ihre eigenen Vorteile: Golang ist für hohe Leistung und gleichzeitige Programmierung geeignet, während Python für Datenwissenschaft und Webentwicklung geeignet ist. Golang ist bekannt für sein Parallelitätsmodell und seine effiziente Leistung, während Python für sein Ökosystem für die kurze Syntax und sein reiches Bibliothek bekannt ist.

Die Leistungsunterschiede zwischen Golang und C spiegeln sich hauptsächlich in der Speicherverwaltung, der Kompilierungsoptimierung und der Laufzeiteffizienz wider. 1) Golangs Müllsammlung Mechanismus ist praktisch, kann jedoch die Leistung beeinflussen.

Golang und C haben jeweils ihre eigenen Vorteile bei Leistungswettbewerben: 1) Golang ist für eine hohe Parallelität und schnelle Entwicklung geeignet, und 2) C bietet eine höhere Leistung und eine feinkörnige Kontrolle. Die Auswahl sollte auf Projektanforderungen und Teamtechnologie -Stack basieren.
