linux日志切割的原理,linux 使用 logrotate 来做日志管理切割

实际使用

在目录/etc/logrotate.d下新建一个web-log/home/zmk/logs/access.log /home/zmk/logs/error.log {

notifempty

daily

rotate 10

dateext

create 0777 zmk zmk

}

测试sudo /usr/sbin/logrotate -f /etc/logrotate.d/web-log

发现新生产的 access.log 和 error.log nginx 没有权限写入,什么鬼?

加上重启命令/home/zmk/logs/access.log /home/zmk/logs/error.log {

notifempty

daily

rotate 10

dateext

create 0777 zmk zmk

sharedscripts

postrotate

if [ -f /home/zmk/lib/tengine/logs/nginx.pid ]; then

kill -USR1 `cat /home/zmk/lib/tengine/logs/nginx.pid`

fi

endscript

}

再次测试,通过。如果不重启,则还是往旧的文件中在写入。

原理分析

logrotate默认被执行是通过/etc/crontab里面的02 4 * * * root run-parts /etc/cron.daily

查看/etc/cron.daily/logrotate#!/bin/sh

/usr/sbin/logrotate /etc/logrotate.conf

EXITVALUE=$?

if [ $EXITVALUE != 0 ]; then

/usr/bin/logger -t logrotate "ALERT exited abnormally with [$EXITVALUE]"

fi

exit 0

而在/etc/logrotate.conf里面有包含了/etc/logrotate.d目录下所有的计划任务。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值