在Go语言中,实现日志轮转通常使用标准库中的log
包和第三方库lumberjack
。下面是一个简单的示例,展示了如何使用lumberjack
库实现日志轮转。
首先,确保已经安装了lumberjack
库。如果没有安装,可以使用以下命令安装:
go get -u gopkg.in/natefinch/lumberjack.v2
接下来,创建一个名为main.go
的文件,并添加以下代码:
package main
import (
"fmt"
"log"
"gopkg.in/natefinch/lumberjack.v2"
)
func main() {
// 设置日志文件名模板,包括时间戳、文件大小等
logFileName := "./logs/myapp-%Y-%m-%d_%H-%M-%S.log"
// 使用lumberjack.Logger进行日志轮转
logger := log.New(lumberjack.NewLogger(logFileName, 10, 2), "", log.LstdFlags)
// 写入日志
for i := 0; i < 10000; i++ {
logger.Println("这是一条日志信息")
}
}
在这个示例中,我们设置了日志文件名模板logFileName
,其中包括时间戳、文件大小等信息。然后,我们使用lumberjack.NewLogger
函数创建了一个lumberjack.Logger
实例,并将其传递给log.New
函数以创建一个新的日志记录器。最后,我们使用logger.Println
方法写入日志。
当你运行这个程序时,它将在logs
目录下生成按时间戳轮转的日志文件。例如,myapp-2022-01-01_12-00-00.log
、myapp-2022-01-01_13-00-00.log
等。