Ungültiger Dateideskriptor beim Versuch, eine Datei anzuhängen
Beim Versuch, innerhalb einer Go-Routine an eine Protokolldatei anzuhängen, kann der Fehler auftreten „write ./log.log: fehlerhafter Dateideskriptor“. Trotz der Existenz der Datei und der entsprechenden Berechtigungen (666) besteht dieses Problem weiterhin.
Anfangs wurde vermutet, dass die Ursache ein gleichzeitiger Dateizugriff durch mehrere Go-Routinen ist. Die Implementierung eines Mutex konnte das Problem jedoch nicht beheben.
Lösung
Die Lösung liegt im Hinzufügen des O_WRONLY-Flags beim Öffnen der Datei:
if f, err := os.OpenFile("./log.log", os.O_APPEND|os.O_WRONLY, os.ModeAppend); err != nil { /*[...]*/ }
Erklärung
Laut der Linux-Dokumentation für open, einer von drei Zugriffen Modi (O_RDONLY, O_WRONLY oder O_RDWR) müssen angegeben werden. Diese Modi erfordern das Öffnen der Datei als schreibgeschützt, schreibgeschützt bzw. lesen/schreiben.
Standardmäßig wird der Dateideskriptor im schreibgeschützten Modus geöffnet, wie durch den folgenden Code in / bestätigt usr/local/go/src/syscall/zerrors_linux_amd64.go:
O_RDONLY = 0x0 O_RDWR = 0x2 O_WRONLY = 0x1
Daher stellt die explizite Angabe von O_WRONLY sicher, dass die Datei wird im schreibgeschützten Modus geöffnet, wodurch das ursprüngliche Problem behoben wird.
Das obige ist der detaillierte Inhalt vonWarum führt das Anhängen an eine Datei in Go zu einem „Bad File Descriptor'-Fehler?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!