请考虑以下代码段。
#include <fcntl.h>
#include <stdio.h>
#include <sys/poll.h>
#include <unistd.h>
int main(int argc, char ** argv) {
int fd;
char buf[1024];
int i;
struct pollfd pfds;
fd = open(argv[1], O_RDONLY);
while (1) {
pfds.fd = fd;
pfds.events = POLLIN;
poll(&pfds, 1, -1);
if (pfds.revents & POLLIN) {
i = read(fd, buf, 1024);
write(1, buf, i);
}
}
return 0;
}
此程序接收文件名,打开相应的文件,并“轮询”其文件描述符,以便监视可用性中的数据。只要poll
检测到可用性数据,就会打印这些新数据。
然而,这个程序会发生什么?如果我要监视的文件在程序启动时已包含数据,则打印其内容。没关系。但是,稍后,当我使用文本编辑器编辑文件并保存时,我的程序不会打印新数据。
那么,如何监控常规文件描述符(不是使用其路径的文件)以获得新数据的可用性?我是否必须使用poll
以外的其他功能?或者我错过了任何pollfd
旗帜?
答案 0 :(得分:5)
您不能在常规文件上使用poll
来监视更改。但是,还有其他几种方法。经典的方法是使用打开的文件描述符定期调用fstat
,并将返回的字段与先前的字段(特别是st_size
)进行比较。现代方法是使用inotify(7)
来监视文件。例如,最近版本的GNU tail使用这种方法:
$ strace tail -f /tmp/foobar
...
open("/tmp/foobar", O_RDONLY) ) = 3
...
inotify_init() = 4
inotify_add_watch(4, "/tmp/foobar", IN_MODIFY|IN_ATTRIB|IN_DELETE_SELF|IN_MOVE_SELF) = 1
...
read(4, ...
有关其工作原理的详细信息,请参见手册页inotify(7)。