在Debian上,Golang日志轮转可以通过使用第三方库或者系统工具来实现。这里我将介绍两种方法:使用第三方库lumberjack
和使用系统工具logrotate
。
方法一:使用第三方库lumberjack
lumberjack
库:go get github.com/natefinch/lumberjack
lumberjack
库并设置日志轮转: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
logrotate
配置文件:sudo nano /etc/logrotate.d/myapp
/var/log/myapp.log {
daily
rotate 7
compress
missingok
notifempty
create 0640 root adm
}
这里的配置表示每天轮转日志文件,保留最近7天的日志文件,压缩旧的日志文件,如果日志文件不存在则不报错,如果日志文件为空则不轮转,创建新的日志文件时设置权限为0640,属主为root,属组为adm。
现在,Golang应用程序的日志将按照logrotate
配置进行轮转。如果你使用的是lumberjack
库,日志轮转将由Golang程序自动处理;如果你使用的是logrotate
工具,日志轮转将由系统定时任务处理。