centos

CentOS中Golang日志文件如何轮转

小樊
45
2025-04-28 23:15:23
栏目: 编程语言

在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会自动处理日志文件的轮转。

0
看了该问题的人还看了