Logrotate日志切割

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点之间选择一个时间执行任务
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

运维生涯记录

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值