在CentOS环境下部署Golang应用,日志管理是运维中不可忽视的关键环节。如果日志文件持续增长不加以控制,磁盘空间迟早会亮起红灯。其实解决方案并不复杂,这里介绍两种经过广泛验证的有效策略,你可以根据实际需求灵活选用。

方法一:利用 logrotate 实现系统级日志轮转
这是最经典且最稳妥的方式——直接将日志管理工作交给操作系统层面的工具。logrotate 在 Linux 生态中已服役多年,稳定可靠,几乎无需在应用代码层面做任何妥协。
首先确认系统是否已安装 logrotate:
sudo yum install logrotate
接着,为你的 Golang 应用创建一份专属配置,例如 /etc/logrotate.d/golang-app,内容参考如下:
/path/to/your/golang-app.log {
daily
rotate 7
compress
missingok
notifempty
create 640 root root
}
解释一下核心参数的作用:daily 表示每日轮转一次;rotate 7 保留最近7天的日志,超出部分自动清除;compress 将过期日志压缩为 gz 格式以节省磁盘空间;missingok 和 notifempty 是实用的细节优化——日志文件缺失时不报错,空文件不触发轮转;create 640 root root 则会在轮转后新建一个权限为 640 的空日志文件。这套配置非常轻量,无需额外调整。
配置完成后,logrotate 会按照 cron 定时任务自动执行轮转,应用本身完全无感知,真正实现零侵入。
方法二:在 Golang 应用代码中内建日志轮转逻辑
如果你希望更精细化地控制日志行为——例如自定义文件名格式、按日志级别分流输出、或对轮转时机有特殊要求——那么在代码层面直接实现是更优选择。第三方日志库 logrus 和 zap 均支持类似功能,此处以 logrus 为例进行演示。
首先安装依赖:
go get github.com/sirupsen/logrus
然后编写一段包含自动轮转功能的日志模块:
package main
import (
"github.com/sirupsen/logrus"
"os"
"time"
)
func main() {
log := logrus.New()
log.Out = os.Stdout
log.SetLevel(logrus.InfoLevel)
log.SetReportCaller(true)
log.SetFormatter(&logrus.JSONFormatter{})
log.SetOutput(os.Stdout)
// 每天凌晨执行一次日志文件轮转
go func() {
for {
time.Sleep(24 * time.Hour)
log.Info("Rotating logs...")
os.Rename("/path/to/your/golang-app.log",
"/path/to/your/golang-app.log."+time.Now().Format("2006-01-02"))
}
}()
log.Info("Hello, World!")
}
这段代码的核心思路是:启动一个后台 goroutine,每隔24小时将当前日志文件重命名为带有日期戳的归档文件;应用写入日志时始终指向原路径,业务逻辑完全不受干扰。当然,生产环境还需要考虑信号处理、同步锁、文件句柄泄漏等细节,但这段示例已经给出了清晰可行的起点。
两种方案各有侧重:logrotate 适合“无侵入、统一管理”的运维场景,而代码内置轮转则提供了更高的灵活度。根据你的运维习惯和项目阶段,选择一种即可顺利落地。
