logrotate切割nohup日志大小不变

阿里云1000元通用代金券点此领取

昨天线上服务器磁盘报警,登录后查看发现单个应用日志nohup.out达到了十几个G,明明做了logrotate日志切割,日志还是在不断的增大

logrotate配置文件如下

/data/tomcat/*/*.log {
su root root  # centos7上不加这里会报错 error: skipping...Set "su" directive in config file to tell logrotate which user/group should be used for rotation.
rotate 15
daily
copytruncate
compress
notifempty
missingok
}

查看 /var/lib/logrotate.status 确实执行了日志切割,而且目录里有日志切割后的压缩文件,大小也正常

通过ll -h 查看日志文件有十几个G,但是用du -sh 文件发现只有几十M

发现启动命令中 nohup xxx.sh > nohup.out & 重定向输出用的是 > ,这种情况如果服务不停止,文件占用的磁盘空间不会被释放。就算手动执行 > nohup.out 清空了日志变成0kb,下一条日志开始写的时候还是会变成清空之前的大小。

解决方案:
> 替换成 >> 追加的形式,就可以被logrotate正常切割
比如nohup xxx.sh >> nohup.out &

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值