加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 服务器 > 搭建环境 > Linux > 正文

linux – tail -f总是使用inotify吗?

发布时间:2020-12-31 05:49:02 所属栏目:Linux 来源:网络整理
导读:我正在使用tail -f(在 Linux上)并试图找出如何使用-s参数来设置轮询间隔.一位同事告诉我-s0会导致尾部使用inotify而不是轮询,但我在尾部的文档中找不到. 我拖尾的二进制文件经常变化 – 这是否表明我应该使用-s0或者一小部分秒(比如-s0.1)? 解决方法 不,t

我正在使用tail -f(在 Linux上)并试图找出如何使用-s参数来设置轮询间隔.一位同事告诉我-s0会导致尾部使用inotify而不是轮询,但我在尾部的文档中找不到.

我拖尾的二进制文件经常变化 – 这是否表明我应该使用-s0或者一小部分秒(比如-s0.1)?

解决方法

不,tail -f并不总是使用inotify.

inotify并不总是可用.即使您的内核支持它,也只有有限数量的句柄可用于使用inotify监视文件,并且它们可能正在其他地方使用.此外,如果传递给tail的名称列表中的任何文件不在本地文件系统上,则将无条件地使用轮询.

这里要做的聪明的事情是相信维护者已经配置了默认行为以适当调整效率和性能的合理平衡,并避免二次猜测.这是双倍的,因为(缺少关于-s 0行为的明确记录的语义)我们在这里给出的任何建议在未来的版本中可能会变得过时.

无论如何:如果您的系统确实支持inotify,那么您将看到比默认的一秒轮询周期更低的延迟,开箱即用,无需调整或非默认选项.

见the actual delay loop used for tail -f with inotify available;您将看到使用-s传递的时间作为select()调用的超时,但只有在inotify不返回该点之前的任何事件时才会达到此超时.

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读