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