在 Go 中将日志消息写入文件
在 Go 中,记录到文件可能是一项简单的任务。但是,某些方法可能会遇到错误,让您想知道为什么日志消息没有写入文件。
失败的方法
提供的代码显示了三个不成功的尝试记录到文件时:
func TestLogging(t *testing.T) { // ... // Attempt #1 log.SetOutput(io.MultiWriter(os.Stderr, f)) log.Println("hello, logfile") // Attempt #2 log.SetOutput(io.Writer(f)) log.Println("hello, logfile") // Attempt #3 log.SetOutput(f) log.Println("hello, logfile") }
这些尝试失败,因为 os.Open() 用于打开日志文件,以只读方式打开文件,这与 log.SetOutput() 所需的写入不兼容。
解决方案
要成功记录到文件,您应该使用os.OpenFile() 改为:
f, err := os.OpenFile("testlogfile", os.O_RDWR | os.O_CREATE | os.O_APPEND, 0666) if err != nil { log.Fatalf("error opening file: %v", err) } defer f.Close() log.SetOutput(f) log.Println("This is a test log entry")
os.OpenFile() 使用读取、写入、创建和附加功能打开文件权限,允许您成功地将日志消息写入文件。请记住在日志记录完成后使用 defer f.Close().
关闭文件以上是为什么我的 Go 日志消息没有写入文件?的详细内容。更多信息请关注PHP中文网其他相关文章!