Golang:附加到日志文件时解决“错误文件描述符”错误
尝试附加到 Go 例程中的日志文件时,一些开发人员遇到“错误的文件描述符”错误。尽管确保文件存在并具有适当的权限,但问题仍然存在。
分析和解决方案
进一步调查显示,错误是由于缺少 O_WRONLY 标志而产生的在 OpenFile 函数调用中。默认情况下,获取的文件描述符是只读的。
要纠正此问题,请将 O_WRONLY 标志添加到 os.OpenFile 函数调用中。下面是更正后的代码:
if f, err := os.OpenFile("./log.log", os.O_APPEND|os.O_WRONLY, os.ModeAppend); err != nil { /*[...]*/ }
如 Linux open 函数手册页中所述,必须指定以下访问模式之一:O_RDONLY、O_WRONLY 或 O_RDWR。这些标志分别表示只读、只写或读/写访问。在这种情况下,单独使用 O_APPEND 会产生只读文件描述符,从而导致错误。添加 O_WRONLY 标志可确保文件描述符为只写。
以上是在 Golang 中附加到日志文件时如何修复'错误文件描述符”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!