debian

Golang日志在Debian中的轮转策略

小樊
47
2025-07-25 15:30:57
栏目: 编程语言

在Debian系统中,Golang日志轮转可以通过使用第三方库或者系统工具来实现。以下是两种常见的方法:

使用第三方库lumberjack

  1. 安装lumberjack库
go get github.com/natefinch/lumberjack
  1. 在Golang代码中设置日志轮转
package main

import (
	"log"
	"github.com/natefinch/lumberjack"
)

func main() {
	log.SetOutput(&lumberjack.Logger{
		Filename:   "/var/log/myapp.log", // 日志文件路径
		MaxSize:    1,                // 每个日志文件的最大尺寸(单位:MB)
		MaxBackups: 3,                // 保留的最大日志文件数量
		MaxAge:     28,               // 保留的最大日志文件天数
		Compress:   true,            // 是否压缩旧的日志文件
	})
	log.Println("This is a log message.")
}

使用系统工具logrotate

  1. 创建logrotate配置文件
sudo nano /etc/logrotate.d/myapp
  1. 添加以下内容到配置文件
/var/log/myapp.log {
    daily
    rotate 7
    compress
    missingok
    notifempty
    create 0640 root adm
}

这个配置表示每天轮转日志文件,保留最近7天的日志文件,压缩旧的日志文件,如果日志文件不存在则不报错,如果日志文件为空则不轮转,创建新的日志文件时设置权限为0640,属主为root,属组为adm。

以上就是在Debian系统中使用Golang实现日志轮转的方法,选择适合你项目需求的方法即可。

0
看了该问题的人还看了