logrotate 程序是一个日志文件管理工具。用于分割日志文件,删除旧的日志文件,并创建新的日志文件,起到“转储”作用。可以节省磁盘空间。下面就对 logrotate 日志轮转操作做一梳理记录。
1、配置文件介绍
Linux系统默认安装logrotate工具,它默认的配置文件在:
/etc/logrotate.conf
/etc/logrotate.d/
Logrotate是基于CRON来运行的,其脚本是/etc/cron.daily/logrotate,日志轮转是系统自动完成的。实际运行时,Logrotate会调用配置文件/etc/logrotate.conf。可以在/etc/logrotate.d目录里放置自定义好的配置文件,用来覆盖Logrotate的缺省值。
如果等不及cron自动执行日志轮转,想手动强制切割日志,需要加-f参数;不过正式执行前最好通过Debug选项来验证一下(-d参数),这对调试也很重要:
/usr/sbin/logrotate -f /etc/logrotate.d/nginx
/usr/sbin/logrotate -d -f /etc/logrotate.d/nginx
1、切割NGINX日志配置
[root@bastion-IDC ~# cat /etc/logrotate.d/nginx
/data/nginx/*.access_log {
daily
copytruncate
rotate 10
compress
dateext
notifempty
missingok
create 644 root root
}
2、切割TOMCAT日志配置
[root@huanqiu-backup ~]# cat /etc/logrotate.d/tomcat
/data/tomcat/logs/catalina.out {
daily
copytruncate
rotate 10
compress
dateext
notifempty
missingok
create 644 root root
}
3、同时切割多个日志
[root@huanqiu-backup ~]# cat /etc/logrotate.d/tomcat
/data/tomcat/logs/catalina.out
/data/tomcat2/logs/catalina.out
/data/tomcat3/logs/catalina.out
/data/nginx/logs/*.log
{
daily
copytruncate
rotate 10
compress
dateext
notifempty
missingok
create 644 root root
}
2、参数说明
选项 | 说明 |
---|---|
sharedscripts | 只为整个日志组运行一次的脚本,运行postrotate脚本,作用是在所有日志都轮转后统一执行一次脚本。如果没有配置这个,那么每个日志轮转后都会执行一次脚本 |
prerotate/endscript | 在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行 |
postrotate/endscript | 在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行 |
compress | 通过gzip 压缩转储以后的日志 |
nocompress | 不做gzip压缩处理 |
notifempty | 如果日志文件为空,不执行切割 |
copytruncate | 用于还在打开中的日志文件,把当前日志备份并截断;是先拷贝再清空的方式,拷贝和清空之间有一个时间差,可能会丢失部分日志数据。 |
nocopytruncate | 备份日志文件不过不截断 |
create mode owner group | 轮转时指定创建新文件的属性,如create 0777 nobody nobody |
nocreate | 不建立新的日志文件 |
delaycompress | 和compress 一起使用时,转储的日志文件到下一次转储时才压缩 |
nodelaycompress | 覆盖 delaycompress 选项,转储同时压缩 |
missingok | 如果日志丢失,不报错继续滚动下一个日志 |
errors address | 专储时的错误信息发送到指定的Email 地址 |
ifempty | 即使日志文件为空文件也做轮转,这个是logrotate的缺省选项 |
notifempty | 当日志文件为空时,不进行轮转 |
mail address | 把转储的日志文件发送到指定的E-mail 地址 |
nomail | 转储时不发送日志文件 |
olddir directory | 转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统 |
noolddir | 转储后的日志文件和当前日志文件放在同一个目录下 |
daily | 指定转储周期为每天 |
weekly | 指定转储周期为每周 |
**monthly ** | 指定转储周期为每月 |
rotate count | 指定日志文件删除之前转储的次数,0 指没有备份,5 指保留5 个备份 ,例如rotate 5 意思只是保存5个备份 |
dateext | 使用当期日期作为命名格式 |
dateformat .%s | 配合dateext使用,紧跟在下一行出现,定义文件切割后的文件名,必须配合dateext使用,只支持 %Y %m %d %s 这四个参数 |
size(或minsize) log-size | 当日志文件到达指定的大小时才转储,log-size能指定bytes(缺省)及KB (sizek)或MB(sizem);当日志文件 >= log-size 的时候就转储。 以下为合法格式:(其他格式的单位大小写没有试过):size = 5 或 size 5 (>= 5 个字节就转储);size = 100k 或 size 100k;size = 100M 或 size 100M |
3、遗留问题
当你设置完成Logrotate你会发现每次切割的日期都是凌晨3点
,那这下也就明白为啥是凌晨3点多切割日志了。你可以修改这儿
/etc/anacron
...
START_HOURS_RANGE=3-22 # 表示3点-22点之间选择一个时间执行任务