2022
我们一起努力

详解nginx日志切割

对于一般的运维和技术来说,每天不是查日志就是在查日志的路上。所以日志的管理规范以及大小,就会影响查看的效率。那该如何合理的管理日志文件的大小呢?下面为大家详细讲解一下nginx日志切割。

详解nginx日志切割

logrotate配置

logrotate 的主配置文件在/etc/logrotate.conf 主配置文件无需进行调整配置,保持默认即可。

如果使用了一键安装包配置的环境,可能在/etc/logrotate.d 下已经生成了文件nginx ,如果没有,则创建该文件:

vim /etc/logrotate.d/nginx
/data/weblogs/*.log {
weekly
rotate 7
missingok
dateext
nocompress
notifempty
sharedscripts
postrotate
[ -e /var/run/nginx.pid ] && kill -USR1 `cat /var/run/nginx.pid`
endscript
}

配置选项说明:

/data/weblogs/*.log # 需要切割的日志文件,可以指定为某个文件名进行切割

weekly #指定转储周期为每周,对应的 daily:指定转储周期为每天,monthly:指定转储周期为每月

rotate 7 #指定日志文件删除之前转储的次数,0 指没有备份,7 指保留7 个备份

missingok #如果指定的目录不存在,logrotate会报错,此项用来关闭报错

nocompress # 这里是不进行压缩,如果需要将切割的日志进行压缩,可以设置为compress

notifempty #如果是空文件的话,不转储

sharedscripts #所有的日志文件都轮转完毕后统一执行一次脚本

postrotate/endscript #在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行

postrotate 中的内容即为:nginx进程发送USR1信号使其重新打开日志并写入,不会重启服务,也不会导致最新写入的日志丢失

如果日志分类存放到不同的目录下可以这样设置:

/data/weblogs/*.log
/data/weblogs/cnyunwei/*.log
{
weekly
rotate 7
.....

测试是否正确执行

[root@aliyun weblogs]#/usr/sbin/logrotate -f /etc/logrotate.d/nginx

执行上述命令后可以查看当前日志文件下生成了www.susecui.cn.log-20160808 的文件,如果是开启了压缩,则会生成www.susecui.cn.log-20160808.gz 的压缩文件

创建任务计划执行命令

如果是设置了每天进行切割日志,那么就需要单独设置计划任务,默认设置为一周切割的情况下不需要设置计划任务,logrotate 主配置文件中已经定义了每周会进行轮询。

crontab -e

10 2 * * 6 /usr/sbin/logrotate -f /etc/logrotate.d/nginx

本文来源:www.lxlinux.net/9742.html,若引用不当,请联系修改。

赞(0)
文章名称:《详解nginx日志切割》
文章链接:https://www.fzvps.com/154945.html
本站文章来源于互联网,如有侵权,请联系管理删除,本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。
图片版权归属各自创作者所有,图片水印出于防止被无耻之徒盗取劳动成果的目的。

评论 抢沙发

评论前必须登录!