在CentOS系统中使用Golang进行日志管理可以通过以下几种方法:
Golang的标准库中提供了 log 包,可以进行基本的日志记录和输出。例如:
package main
import (
    "log"
    "os"
)
func main() {
    log.SetOutput(os.Stdout) // 设置日志输出到标准输出
    log.Println("这是一条普通日志")
    log.Fatalf("这是一条严重错误日志: %s", "错误信息")
}
可以使用一些功能更强大的第三方日志库,如 logrus 或 zap。这些库通常提供更多的功能和更好的性能。例如,使用 zap:
package main
import (
    "go.uber.org/zap"
)
func main() {
    logger := zap.NewProduction()
    defer logger.Sync()
    logger.Info("这是一条普通日志")
    logger.Error("这是一条错误日志", zap.String("err", "错误信息"))
}
安装 Supervisor:
sudo yum install supervisor -y
创建 Supervisor 配置文件:
在 /etc/supervisord.d 目录下创建一个新的配置文件,例如 app.ini:
[program:app]
directory=/path/to/your/app
command=/path/to/your/app/dist/app-linux-amd64 -param1 "value1" -param2 "value2"
autostart=true
autorestart=true
stderr_logfile=/path/to/your/app/log/app.err.log
stdout_logfile=/path/to/your/app/log/app.log
environment ENV_VAR1="value3",ENV_VAR2="value4"
启动 Supervisor:
sudo systemctl start supervisord
sudo systemctl status supervisord
sudo systemctl enable supervisord
为了避免日志文件过大,可以使用 logrotate 工具进行日志轮转。首先,安装 logrotate:
sudo yum install logrotate
然后,创建一个 logrotate 配置文件,例如:
/path/to/your/logfile.log {
    daily
    rotate 7
    compress
    missingok
    notifempty
}
将此配置文件添加到 /etc/logrotate.d/ 目录中,并确保 cron 任务定期运行 logrotate:
echo "* * * * * /usr/sbin/logrotate /path/to/your/logrotate.conf" | crontab -
查看系统日志:
sudo journalctl -u systemd.service
sudo journalctl -n 100