Golang: Behebung des Fehlers „Bad File Descriptor“ beim Anhängen an eine Protokolldatei
Beim Versuch, innerhalb einer Go-Routine an eine Protokolldatei anzuhängen Bei einigen Entwicklern tritt der Fehler „Ungültiger Dateideskriptor“ auf. Obwohl sichergestellt wurde, dass die Datei vorhanden ist und über die entsprechenden Berechtigungen verfügt, besteht das Problem weiterhin.
Analyse und Lösung
Weitere Untersuchungen ergeben, dass der Fehler auf das Fehlen der O_WRONLY-Flagge zurückzuführen ist im OpenFile-Funktionsaufruf. Standardmäßig ist der erhaltene Dateideskriptor schreibgeschützt.
Um dieses Problem zu beheben, fügen Sie dem Funktionsaufruf os.OpenFile das Flag O_WRONLY hinzu. Hier ist der korrigierte Code:
if f, err := os.OpenFile("./log.log", os.O_APPEND|os.O_WRONLY, os.ModeAppend); err != nil { /*[...]*/ }
Wie in der Manpage der Linux-Open-Funktion dokumentiert, muss einer der folgenden Zugriffsmodi angegeben werden: O_RDONLY, O_WRONLY oder O_RDWR. Diese Flags zeigen schreibgeschützten, schreibgeschützten bzw. Lese-/Schreibzugriff an. In diesem Fall führt die alleinige Verwendung von O_APPEND zu einem schreibgeschützten Dateideskriptor, was zu dem Fehler führt. Durch das Hinzufügen des O_WRONLY-Flags wird ein schreibgeschützter Dateideskriptor sichergestellt.
Das obige ist der detaillierte Inhalt vonWie behebt man den Fehler „Bad File Descriptor' beim Anhängen an die Protokollierungsdatei in Golang?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!