【Nginx】Linux系统自动切割Nginx日志之logrotate篇

背景

​ 日志文件包含了关于系统中发生的事件的有用信息,在排障过程中或者系统性能分析时经常被用到。对于忙碌的服务器,日志文件大小会增长极快,服务器会很快消耗磁盘空间,这成了个问题。除此之外,处理一个单个的庞大日志文件也常常是件十分棘手的事。
  logrotate是个十分有用的工具,它可以自动对日志进行截断(或轮循)、压缩以及删除旧的日志文件。例如,你可以设置logrotate,让/var/log/foo日志文件每30天轮循,并删除超过6个月的日志。配置完后,logrotate的运作完全自动化,不必进行任何进一步的人为干预。

​ Nginx是我们经常使用的一个高性能的HTTP和反向代理web服务器,那么如果你的网站访问比较频繁的话,nginx的日志文件会越来越大。第一种办法就是禁用Nginx的日志输出(不建议),第二种办法是人工,就是每天自己闲着无聊可以上去手动操作。 第三种呢就是自动切割了,那网上自动切割的有很多种,楼主说的是Linux系统自带的logrotate,贼好用,操作简单快速。不说有的没的,直接上步骤。

操作
步骤1

在linux系统的 /etc/logrotate.d目录下创建一个文件 叫做 nginx

【Nginx】Linux系统自动切割Nginx日志之logrotate篇_第1张图片

步骤2

在nginx文件里复制以下的内容

/usr/local/nginx/logs/*.log {  
    daily  
    rotate 31  
    missingok  
    notifempty  
    nocompress  
    postrotate  
        /bin/kill -USR1 $(cat /usr/local/nginx/logs/nginx.pid 2>/dev/null) 2>/dev/null || :  
    endscript  
}

到此已经就可以了,那么如何知道自己操作的有没有起效果呢。以下是测试和手动执行的命令

# 携带-d的是 debug模式,测试模拟结果有没有问题
/usr/sbin/logrotate -d -f /etc/logrotate.d/nginx
# 直接就是-f 是手动执行一次
/usr/sbin/logrotate -f /etc/logrotate.d/nginx

执行成功的效果应该就是你放置nginx的日志目录 access.log被切割了成了新的文件

【Nginx】Linux系统自动切割Nginx日志之logrotate篇_第2张图片

你可能感兴趣的:(Nginx,linux,nginx,服务器)