centos

CentOS上Golang日志如何切割

小樊
43
2025-08-14 19:30:41
栏目: 编程语言

在CentOS上,你可以使用logrotate工具来实现Golang应用程序的日志切割。以下是配置和使用logrotate的方法:

  1. 首先确保你的Golang应用程序将日志输出到文件中。例如,你可以在Golang代码中使用log包将日志输出到文件:
package main

import (
	"log"
	"os"
)

func main() {
	logFile, err := os.OpenFile("app.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
	if err != nil {
		log.Fatal(err)
	}
	defer logFile.Close()

	log.SetOutput(logFile)
	log.Println("Hello, World!")
}
  1. /etc/logrotate.d/目录下创建一个新的配置文件,例如golang-app
sudo touch /etc/logrotate.d/golang-app
  1. 使用文本编辑器打开golang-app文件,并添加以下内容:
/path/to/your/golang-app.log {
    daily
    rotate 7
    compress
    missingok
    notifempty
    create 0640 root root
}

这里的配置表示:

请将/path/to/your/golang-app.log替换为你的Golang应用程序的实际日志文件路径。

  1. 保存并关闭文件。

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

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

这将强制执行日志切割,你可以检查/var/lib/logrotate/status文件以确保没有错误。

现在,你的Golang应用程序的日志将根据logrotate配置进行自动切割。

0
看了该问题的人还看了