在Golang中,你可以使用标准库"log"来配置日志输出。以下是一个简单的示例,展示了如何配置日志输出到控制台和文件:
package main
import (
"log"
"os"
)
logFile, err := os.OpenFile("logs.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
if err != nil {
log.Fatalf("error opening log file: %v", err)
}
defer logFile.Close()
log.SetOutput(io.MultiWriter(os.Stdout, logFile))
log包中的函数记录日志:log.Println("This is a log message.")
log.Printf("This is a formatted log message with a number: %d", 42)
log.Fatalf("This is a fatal error message.")
这个示例将日志输出到控制台和名为logs.log的文件中。你可以根据需要调整日志级别、格式和输出目标。例如,你可以使用log.SetPrefix()和log.SetFlags()函数来自定义日志前缀和标志。
以下是一个更详细的示例,展示了如何配置日志级别和格式:
package main
import (
"io"
"log"
"os"
"time"
)
func main() {
logFile, err := os.OpenFile("logs.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
if err != nil {
log.Fatalf("error opening log file: %v", err)
}
defer logFile.Close()
multiWriter := io.MultiWriter(os.Stdout, logFile)
log.SetOutput(multiWriter)
log.SetPrefix(time.Now().Format("2006-01-02 15:04:05") + " ")
log.SetFlags(log.Ldate | log.Ltime | log.Lshortfile)
log.Println("This is a log message.")
log.Printf("This is a formatted log message with a number: %d", 42)
log.Fatalf("This is a fatal error message.")
}
这个示例将日志输出到控制台和文件,并在每条日志消息前添加时间戳和文件名。