Heim >Backend-Entwicklung >Golang >Warum führt das Anhängen an eine Datei in Go zu einem „Bad File Descriptor'-Fehler?

Warum führt das Anhängen an eine Datei in Go zu einem „Bad File Descriptor'-Fehler?

Susan Sarandon
Susan SarandonOriginal
2024-11-11 15:56:03799Durchsuche

Why Does Appending to a File Result in a

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn