微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

linux – logrotate如何处理并发?

如果logrotate在更新日志文件的同时运行,会发生什么?
新日志是否会旋转到历史日志文件中?或者它将保留在当前日志文件中?

谢谢,

解决方法

在轮换日志期间,消息可以以旧文件或新文件结束,但是以确定的方式. Logrotate对每个日志文件大致执行以下操作:

>将日志重命名为存档名称
>通知应用程序重新打开其日志
>可选择压缩日志文件

如果消息记录在1和2之间,则这些消息将在重命名的日志中结束,因为重命名不会影响打开的文件描述符(这也是压缩仅在应用程序重新打开日志后发生的原因).在2之后记录的消息将在新日志中结束.

这是我的logrotate配置的摘录,它执行我为Nginx’日志描述的内容

/var/log/Nginx/*.log {
    compress
    delaycompress
    postrotate
        [ ! -f /run/Nginx.pid ] || kill -USR1 `cat /run/Nginx.pid`
    endscript
}

原文地址:https://www.jb51.cc/linux/399328.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐