温馨提示×

如何在Golang中配置日志输出

小樊
48
2025-11-03 08:17:06
栏目: 编程语言

在Golang中,你可以使用标准库"log"来配置日志输出。以下是一个简单的示例,展示了如何配置日志输出到控制台和文件:

  1. 首先,导入所需的包:
package main

import (
	"log"
	"os"
)
  1. 接下来,创建一个日志文件,并检查是否有错误:
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()
  1. 然后,配置日志输出到控制台和文件:
log.SetOutput(io.MultiWriter(os.Stdout, logFile))
  1. 最后,使用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.")
}

这个示例将日志输出到控制台和文件,并在每条日志消息前添加时间戳和文件名。

0