在CentOS上配置Golang應用程序的日志,通常會使用標準庫log
或者第三方日志庫如logrus
、zap
等。以下是使用標準庫log
進行日志配置的基本步驟:
log
包。import (
"log"
"os"
)
log.SetOutput
函數來改變日志的輸出目標,比如輸出到文件或者標準錯誤。// 輸出到標準錯誤
log.SetOutput(os.Stderr)
// 或者輸出到文件
file, err := os.OpenFile("app.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
if err == nil {
log.SetOutput(file)
} else {
log.Fatal(err)
}
log.SetPrefix
和log.SetFlags
來設置日志的前綴和標志。// 設置日志前綴
log.SetPrefix("INFO: ")
// 設置日志標志,比如日期、時間、文件名和行號
log.SetFlags(log.Ldate | log.Ltime | log.Lshortfile)
log.Println
、log.Printf
和log.Fatal
等函數來記錄日志。log.Println("這是一條普通日志")
log.Printf("這是一條格式化日志: %d", 123)
if err != nil {
log.Fatal(err) // 記錄錯誤并退出程序
}
lumberjack
來實現。首先,安裝lumberjack
庫:
go get gopkg.in/natefinch/lumberjack.v2
然后,在代碼中使用lumberjack.Logger
:
import (
"log"
"gopkg.in/natefinch/lumberjack.v2"
)
func main() {
log.SetOutput(&lumberjack.Logger{
Filename: "/var/log/myapp.log", // 日志文件路徑
MaxSize: 10, // 單個日志文件最大尺寸(MB)
MaxBackups: 3, // 最多保留的舊日志文件數量
MaxAge: 28, // 最多保留的舊日志文件天數
Compress: true, // 是否壓縮舊日志文件
})
// 使用標準log包記錄日志
log.Println("這是一條帶有日志輪轉功能的日志")
}
以上就是在CentOS上配置Golang應用程序日志的基本步驟。根據你的需求,你可以選擇合適的日志級別、格式和輸出目標。如果需要更高級的日志功能,可以考慮使用第三方日志庫。