如何监视文件描述符以获取新数据的可用性?

时间:2013-06-16 14:35:23

标签: linux polling file-descriptor

请考虑以下代码段。

#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旗帜?

1 个答案:

答案 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)