日志切割之 logrotate

2019-9-8 Frank 服务器

安装

# ubuntu
apt-get install logrotate cron
# centos
yum install logrotate crontabs

docker kong log demo

vim /etc/logrotate.d/kong_error

/srv/docker/kong-gateway/logs/error.log {
    monthly    # 日志文件将按月轮循。其它可用值为'daily','weekly'或者'yearly'。
    rotate 5   # 一次将存储5个归档日志。对于第六个归档,时间最久的归档将被删除。
    dateext    # 让旧日志文件以创建日期命名
    compress   # 在轮循任务完成后,已轮循的归档将使用gzip进行压缩。
    delaycompress #总是与compress选项一起用,delaycompress选项指示logrotate不要将最近的归档压缩,压缩将在下一次轮循周期进行。这在你或任何软件仍然需要读取最新归档时很有用。
    missingok  # 在日志轮循期间,任何错误将被忽略,例如“文件无法找到”之类的错误。
    notifempty # 如果日志文件为空,轮循不会进行。
    create 644 root root # 以指定的权限创建全新的日志文件,同时logrotate也会重命名原始日志文件。
    postrotate
        docker inspect -f '{{ .State.Pid }}' kong | xargs kill -USR1
    endscript  # 在所有其它指令完成后,postrotate和endscript里面指定的命令将被执行。在这种情况下,rsyslogd 进程将立即再次读取其配置并继续运行。
}

nginx log demo

vim /etc/logrotate.d/nginx_error

/var/nginx/log/www_access.log {
    monthly
    size=500M
    rotate 5
    dateext
    compress
    delaycompress
    missingok
    notifempty
    create 644 root root
    postrotate
      /bin/kill -USR1 `cat /opt/nginx/logs/nginx.pid 2>/dev/null` 2>/dev/null || true
    endscript
}

测试

# 运行所有
logrotate /etc/logrotate.conf
# 调用某一个
logrotate /etc/logrotate.d/log-file
# 演练
logrotate -d /etc/logrotate.d/log-file
# 强制
logrotate -f /etc/logrotate.d/log-file
# 默认log `/var/lib/logrotate/status`, 指定log文件
logrotate -vf –s /var/log/logrotate-status /etc/logrotate.d/log-file

参考
Linux日志文件总管——logrotate
nginx docker 方式启动后日志切分的正确姿势
日志切割之Logrotate

标签: linux logrotate

发表评论 登录

Top