在Golang中,可以使用第三方库来实现日志轮转。一个流行的库是lumberjack。以下是如何使用lumberjack库实现日志轮转的步骤:
lumberjack库。在命令行中运行以下命令:go get github.com/natefinch/lumberjack/v2
lumberjack库和其他必要的库:package main
import (
"log"
"os"
"time"
"github.com/natefinch/lumberjack/v2"
)
lumberjack.Logger实例,并将其设置为标准日志输出:func main() {
log.SetOutput(&lumberjack.Logger{
Filename: "logs/myapp.log", // 日志文件名
MaxSize: 1, // 每个日志文件的最大大小(以MB为单位)
MaxBackups: 3, // 保留的最大日志文件数
MaxAge: 28, // 保留的最大日志文件天数
Compress: true, // 是否压缩旧日志文件
})
log包记录日志。当日志文件达到指定的最大大小时,lumberjack会自动创建一个新的日志文件,并根据配置保留一定数量的旧日志文件。func main() {
log.SetOutput(&lumberjack.Logger{
Filename: "logs/myapp.log",
MaxSize: 1,
MaxBackups: 3,
MaxAge: 28,
Compress: true,
})
for i := 0; i < 100; i++ {
log.Printf("This is a log message %d", i)
time.Sleep(1 * time.Second)
}
}
这个例子中,当日志文件大小超过1MB时,lumberjack会自动创建一个新的日志文件,并保留最近3个压缩的旧日志文件。旧日志文件将保留28天。
你可以根据自己的需求调整lumberjack.Logger的配置参数。更多关于lumberjack库的信息,请参考官方文档:https://github.com/natefinch/lumberjack