Problèmes de descripteur de fichier dans Golang : "Mauvais descripteur de fichier" résolus
Lors de la tentative d'ajout à un fichier de journalisation dans une routine Go, les développeurs peut rencontrer une erreur « mauvais descripteur de fichier ». Ce problème peut être particulièrement déroutant lorsque le fichier existe et dispose des autorisations appropriées.
Au départ, il peut sembler que plusieurs routines tentant d'ouvrir le fichier simultanément pourraient être à l'origine du problème. Cependant, même après avoir implémenté un mutex pour éviter cela, la même erreur persiste.
La solution réside dans l'ajout de l'indicateur O_WRONLY à l'instruction d'ouverture du fichier. Par défaut, l'opération d'ouverture ouvre le fichier en mode lecture seule. Sans spécifier explicitement un indicateur d'écriture seule, toute tentative d'écriture dans le fichier échouera avec l'erreur « mauvais descripteur de fichier ».
Voici une version modifiée de l'extrait de code qui inclut l'indicateur O_WRONLY :
if f, err := os.OpenFile("./log.log", os.O_APPEND|os.O_WRONLY, os.ModeAppend); err != nil { panic(err) }
Avec cette modification, le fichier sera ouvert avec des autorisations d'ajout et d'écriture seule, résolvant l'erreur "mauvais descripteur de fichier" et permettant une écriture réussie dans le fichier de journalisation.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!