一、logrotate介绍
logrotate软件是一个日志管理工具,用于非分隔日志,删除旧的日志文件,并创建新的日志文件,起到“转储作用”,可以为系统节省磁盘空间。一般centos系统已经自带安装好了。
logrotate是基于crontab运行的,其脚本是/etc/cron.daily/logtotate,日志轮转是系统自发完成的,实际运行时,logrotate会调用配置文件/etc/logrotate.conf。可以在/etc/logrotate.d目录里放置自定义好的配置文件,用来覆盖logrotate.conf的缺省值。
二、logrotate配置文件
2.1 logrotate默认配置文件
[root@linux-node1 ~]# grep -v '^#' /etc/logrotate.conf weekly #默认每周执行一次日志轮询 rotate 4 #默认保留4个日志文件 create #自动创建新的日志文件,新的文件和原来的文件具有相同的权限 dateext #日志切割后,文件以当前日志为结尾,例如:messages-20181125 include /etc/logrotate.d #将/etc/logrotate.d目录中的配置文件加载进来 /var/log/wtmp { #针对wtmp日志的配置参数 monthly #每月切割一次 create 0664 root utmp #新建日志的权限为0644,属主为root,属组为utmp minsize 1M #文件大小超过1M后才会切割 rotate 1 #只保留1个日志文件 } /var/log/btmp { missingok monthly create 0600 root utmp rotate 1 }
2.2 logrotate常用参数
配置参数 功能说明 compress #通过gzip,压缩转储以后的日志 nocompress #不需要压缩时,用这个参数 copytruncate #用于还在打开中的日志文件,把当前日志备份并截断 nocopytruncate #备份日志文件但是不截断 create mode owner group #转储文件,使用指定的文件模式创建新的日志文件 nocreate #不建立新的日志文件 delaycompress 和 compress #一起使用时,转储的日志文件到下一次转储时才压缩 nodelaycompress #覆盖delaycompress 选项,转储同时压缩。 errors address #专储时的错误信息发送到指定的Email 地址 ifempty #即使是空文件也转储,这个是 logrotate 的缺省选项。 notifempty #如果是空文件的话,不转储 mail address #把转储的日志文件发送到指定的E-mail 地址 nomail #转储时不发送日志文件 olddir directory #转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统 noolddir #转储后的日志文件和当前日志文件放在同一个目录下 prerotate/endscript #在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行 postrotate/endscript #在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行 daily #指定转储周期为每天 weekly #指定转储周期为每周 monthly #指定转储周期为每月 rotate count #指定日志文件删除之前转储的次数,0 指没有备份,5 指保留5 个备份 size(或minsize) #size当日志文件到达指定的大小时才转储,Size 可以指定 bytes (缺省)以及KB (sizek)或者MB (sizem).
2.3 nginx日志文件的切割
[root@linux-node1 ~]# cat /etc/logrotate.d/nginx /var/log/nginx/*.log { #日志文件的路径 daily #每天切割
dateext #日志切割后,文件以当前日志为结尾,例如:access-logs-20181125 missingok #日志不存在分析,分析下一个 rotate 30 #日志保留30份 compress #转存之后压缩.tar.gz delaycompress #日志压缩会被延后到下次分割时进行 notifempty #空文件不转储 create 644 nginx adm #新日志文件权限 sharedscripts #整个日志组运行一次脚本 postrotate [ -f /var/run/nginx.pid ] && kill -USR1 `cat /var/run/nginx.pid` #重启nginx,重新加载日志文件,防止日志无法写入新文件 endscript #结束脚本 }
[root@linux-node1 ~]# logrotate -d /etc/logrotate.d/nginx #进行日志切割测试
[root@linux-node1 ~]# cat /etc/anacrontab #生效时间是在凌晨3点到22点之间,而且随机延迟时间是45分钟
# /etc/anacrontab: configuration file for anacron
# See anacron(8) and anacrontab(5) for details.
SHELL=/bin/sh
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
# the maximal random delay added to the base delay of the jobs
RANDOM_DELAY=45
# the jobs will be started during the following hours only
START_HOURS_RANGE=3-22
#period in days delay in minutes job-identifier command
1 5 cron.daily nice run-parts /etc/cron.daily
7 25 cron.weekly nice run-parts /etc/cron.weekly
@monthly 45 cron.monthly nice run-parts /etc/cron.monthly