首页 >后端开发 >Golang >为什么我的 Go 日志消息没有写入文件?

为什么我的 Go 日志消息没有写入文件?

Patricia Arquette
Patricia Arquette原创
2024-12-10 00:46:11434浏览

Why Aren't My Go Log Messages Writing to the File?

在 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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn