系统相关
首页 > 系统相关> > linux – 如何监视文件描述符以获得新数据的可用性?

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

作者:互联网

请考虑以下代码段.

#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;
}

该程序接收文件名,打开相应的文件,并“轮询”其文件描述符,以便监视可用性中的数据.每当轮询检测到可用性数据时,都会打印这些新数据.

但是,这个程序会发生什么?如果我要监视的文件在程序启动时已包含数据,则打印其内容.没关系.但是,稍后,当我使用文本编辑器编辑文件并保存它时,我的程序不会打印新数据.

那么,如何监视常规文件描述符(不是使用其路径的文件)以获得新的数据可用性?我是否必须使用民意以外的其他功能?或者我错过任何pollfd旗帜?

解决方法:

您不能在常规文件上使用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)页.

标签:linux,file-descriptor,polling
来源: https://codeday.me/bug/20190620/1243538.html