温馨提示×

Linux readdir如何支持文件监控

小樊
32
2025-12-17 08:21:47
栏目: 智能运维

在Linux中,readdir函数用于读取目录中的条目。然而,readdir本身并不直接支持文件监控。要实现文件监控,你可以使用其他机制,如inotifyfswatch

以下是使用inotifyreaddir结合实现文件监控的方法:

  1. 首先,确保你的系统已经安装了inotify-tools。在Debian/Ubuntu上,可以使用以下命令安装:
sudo apt-get install inotify-tools
  1. 创建一个C程序,使用inotify_init创建一个inotify实例,然后使用inotify_add_watch添加要监控的目录。接下来,使用read系统调用读取inotify事件,并根据事件类型(如IN_MODIFYIN_CREATE等)判断文件是否发生变化。

  2. 当检测到文件变化时,使用readdir重新读取目录内容,以便更新文件列表。

以下是一个简单的示例:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/inotify.h>
#include <dirent.h>
#include <unistd.h>

#define EVENT_SIZE  ( sizeof (struct inotify_event) )
#define BUF_LEN     ( 1024 * ( EVENT_SIZE + 16 ) )

int main(int argc, char **argv)
{
    int length, i = 0;
    int fd;
    int wd;
    char buffer[BUF_LEN];

    // 监控的目录
    const char *watch_dir = "/path/to/watch";

    fd = inotify_init();
    if (fd < 0) {
        perror("inotify_init");
        return 1;
    }

    wd = inotify_add_watch(fd, watch_dir, IN_MODIFY | IN_CREATE | IN_DELETE);
    if (wd < 0) {
        perror("inotify_add_watch");
        return 1;
    }

    while (1) {
        length = read(fd, buffer, BUF_LEN);
        if (length < 0) {
            perror("read");
            return 1;
        }

        while (i < length) {
            struct inotify_event *event = (struct inotify_event *) &buffer[i];
            if (event->len) {
                if (event->mask & IN_MODIFY) {
                    printf("File modified: %s\n", event->name);
                } else if (event->mask & IN_CREATE) {
                    printf("File created: %s\n", event->name);
                } else if (event->mask & IN_DELETE) {
                    printf("File deleted: %s\n", event->name);
                }
            }
            i += EVENT_SIZE + event->len;
        }
        i = 0;

        // 重新读取目录内容
        DIR *dir = opendir(watch_dir);
        if (dir == NULL) {
            perror("opendir");
            return 1;
        }

        struct dirent *entry;
        while ((entry = readdir(dir)) != NULL) {
            printf("Readdir: %s\n", entry->d_name);
        }

        closedir(dir);
    }

    (void) inotify_rm_watch(fd, wd);
    (void) close(fd);

    return 0;
}

编译并运行此程序,它将监控指定目录中的文件变化,并在检测到变化时重新读取目录内容。请注意,这个示例仅用于演示目的,实际应用中可能需要更复杂的逻辑来处理各种情况。

0