温馨提示×

Golang 程序日志在 CentOS 上如何分类存储

小樊
94
2025-02-08 23:23:12
栏目: 云计算
GO开发者专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

在 CentOS 上,您可以使用日志管理工具(如 logrotate)对 Golang 程序的日志进行分类存储

  1. 首先,确保您已经在 CentOS 上安装了 logrotate。如果没有,请使用以下命令安装:
sudo yum install logrotate
  1. 创建一个新的 logrotate 配置文件,例如 /etc/logrotate.d/golang。在这个文件中,您可以定义日志的分类存储规则。以下是一个示例配置:
/path/to/your/golang/app/*.log {
    daily
    rotate 7
    compress
    delaycompress
    missingok
    notifempty
    create 0640 root adm
    sharedscripts
    postrotate
        /path/to/your/golang/app/restart.sh
    endscript
}

在这个示例中,我们定义了以下规则:

  • 每天旋转日志文件(daily
  • 保留最近 7 天的日志文件(rotate 7
  • 使用 gzip 压缩旧的日志文件(compress
  • 在下一次日志轮转之前延迟压缩(delaycompress
  • 如果日志文件丢失,不报错(missingok
  • 仅在日志文件非空时进行轮转(notifempty
  • 以 0640 的权限创建新的日志文件,属于 root 和 adm 用户(create 0640 root adm
  • 使用 sharedscripts 选项,以便在多个日志文件之间共享 postrotate 和 endscript 部分(sharedscripts
  • 在日志轮转后,执行 restart.sh 脚本来重启 Golang 应用程序(postrotate
  1. 根据您的 Golang 应用程序的日志文件路径,修改 /etc/logrotate.d/golang 配置文件中的 /path/to/your/golang/app/*.log

  2. 测试 logrotate 配置是否正确:

sudo logrotate -d /etc/logrotate.d/golang

如果没有错误,您的配置应该是正确的。

  1. 最后,确保 logrotate 定期运行以自动分类存储日志文件。您可以通过将 logrotate 添加到系统的 crontab 中来实现这一点。例如,要每天凌晨运行 logrotate,请将以下内容添加到 /etc/crontab 文件中:
0 0 * * * /usr/sbin/logrotate /etc/logrotate.conf

现在,您的 Golang 程序日志应该会根据您在 logrotate 配置文件中定义的规则进行分类存储。

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读:Golang日志在CentOS如何压缩存储

0