在 Go 中记录到控制台和文件
在 Go 中,您可以使用 log.SetOutput(logFile 轻松将日志消息定向到文件)。但是,如果您还想在控制台中显示这些消息怎么办?
使用 io.MultiWriter
要实现此目的,您可以使用 io.MultiWriter。这将创建一个写入器,将其写入复制到所有提供的写入器。这类似于 Unix tee(1) 命令。
logFile, err := os.OpenFile("log.txt", os.O_CREATE|os.O_APPEND|os.O_RDWR, 0666) if err != nil { panic(err) } // Create a MultiWriter that writes to both the console and the file. mw := io.MultiWriter(os.Stdout, logFile) // Set the logger's output to the MultiWriter. log.SetOutput(mw)
在此示例中,原始代码的唯一更改是创建 io.MultiWriter 并将记录器的输出设置为其。现在,所有日志消息都将写入控制台和指定文件,提供了一种实时监控日志的便捷方法,同时还维护持久日志。
以上是如何在 Go 中同时登录到控制台和文件?的详细内容。更多信息请关注PHP中文网其他相关文章!