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

检测到POSIX系统上的日志文件已被删除或截断?

假设一个长时间运行的进程写入日志文件.假设日志文件无限期保持打开状态.假设粗心的系统管理员删除该日志文件.程序可以检测到这种情况发生了吗?

是否可以安全地假设fstat()将为已删除文件报告链接计数为零?

在我看来,截断有点棘手.在某种程度上,它取决于文件描述符是否在O_APPEND模式下运行.如果日志文件没有与O_APPEND一起运行,那么程序日志描述符的当前写入位置不会改变,截断将删除前导字节,但程序继续写入“结束”,留下幻像的空白零字节(它们读为零,但不一定占用磁盘空间).

如果程序使用O_APPEND运行,那么它将在文件末尾写入,因为它当前存在.观察截断的唯一方法是注意文件位置不是程序所期望的位置 – 这反过来意味着明确地跟踪该位置.

总的来说,我并不担心截断是删除,但任何想法都会受到欢迎.

解决方法

如果文件被硬链接重命名,则检查fstat()返回链接计数为零将失败.我可能会定期将stat()的inode数与fstat()进行比较.

我不确定截断.

tail -F检查删除和截断,所以我检查它的来源,看看它是如何实现它的.

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

相关推荐