在CentOS系统中,使用Golang编写的应用程序可以通过配置日志库来实现日志文件的轮转。一个常用的日志库是logrus
,另一个流行的选择是zap
。这里以logrus
为例,介绍如何实现日志文件的轮转。
首先,确保已经安装了logrus
库:
go get github.com/sirupsen/logrus
然后,在你的Golang代码中,可以按照以下方式配置logrus
以实现日志文件的轮转:
package main
import (
"github.com/sirupsen/logrus"
"os"
"time"
)
func main() {
// 创建一个新的日志实例
logger := logrus.New()
// 设置日志输出到文件
logFile, err := os.OpenFile("logs/app.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
if err != nil {
logrus.Fatal(err)
}
defer logFile.Close()
// 设置日志格式为文本格式
logger.SetFormatter(&logrus.TextFormatter{
FullTimestamp: true,
})
// 设置日志级别
logger.SetLevel(logrus.InfoLevel)
// 设置日志文件轮转
logger.Out = logFile
logger.SetReportCaller(true)
// 每天轮转一次日志文件
ticker := time.NewTicker(24 * time.Hour)
go func() {
for range ticker.C {
logger.Info("Rotating logs...")
logFile.Close()
os.Rename("logs/app.log", "logs/app-"+time.Now().Format("2006-01-02")+".log")
logFile, err = os.OpenFile("logs/app.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
if err != nil {
logrus.Error(err)
}
logger.Out = logFile
}
}()
// 写入日志
logger.Info("This is an info message.")
logger.Warn("This is a warning message.")
logger.Error("This is an error message.")
}
在这个示例中,我们创建了一个新的日志实例,并将其输出设置为文件logs/app.log
。然后,我们启动了一个goroutine,每隔24小时关闭当前日志文件,将旧的日志文件重命名为logs/app-YYYY-MM-DD.log
,并创建一个新的日志文件。这样就实现了日志文件的轮转。
注意:这个示例仅用于演示目的,实际应用中可能需要根据需求进行调整。在生产环境中,可以考虑使用现有的日志库,如lumberjack
,它提供了更强大的日志轮转功能。要使用lumberjack
,请先安装:
go get gopkg.in/natefinch/lumberjack.v2
然后在代码中使用lumberjack.Logger
替换os.File
:
import (
"github.com/sirupsen/logrus"
"gopkg.in/natefinch/lumberjack.v2"
)
func main() {
logger := logrus.New()
// 设置日志输出到文件,并配置轮转参数
logWriter := &lumberjack.Logger{
Filename: "logs/app.log",
MaxSize: 10, // 每个日志文件最大10MB
MaxBackups: 3, // 最多保留3个旧日志文件
MaxAge: 28, // 最多保留28天
Compress: true, // 是否压缩旧日志文件
}
logger.SetOutput(logWriter)
// 其他配置和代码与上面的示例相同
}
这样,lumberjack
会自动处理日志文件的轮转。