在CentOS上,你可以使用logrotate工具来实现Golang应用程序的日志切割。以下是配置和使用logrotate的方法:
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!")
}
/etc/logrotate.d/目录下创建一个新的配置文件,例如golang-app:sudo touch /etc/logrotate.d/golang-app
golang-app文件,并添加以下内容:/path/to/your/golang-app.log {
daily
rotate 7
compress
missingok
notifempty
create 0640 root root
}
这里的配置表示:
daily: 每天切割日志文件。rotate 7: 保留7天的日志文件。compress: 压缩旧的日志文件。missingok: 如果日志文件不存在,不会报错。notifempty: 如果日志文件为空,不进行切割。create 0640 root root: 创建新的日志文件,权限为0640,属主为root,属组为root。请将/path/to/your/golang-app.log替换为你的Golang应用程序的实际日志文件路径。
保存并关闭文件。
测试logrotate配置是否正确:
sudo logrotate -f /etc/logrotate.d/golang-app
这将强制执行日志切割,你可以检查/var/lib/logrotate/status文件以确保没有错误。
现在,你的Golang应用程序的日志将根据logrotate配置进行自动切割。