那么,Dorpbox 是怎么知道目录的文件发生了改变呢?答案是,通过 inotfiy 这个系统功能来实现的。
我们主要分为两篇文章来介绍 inotify 这个功能:本篇首先介绍 inotify 的使用方式,而下篇主要介绍 inotify 的实现原理。
inotify 接口们
其实 inotify 的接口比较少,只有3个:inotify_init、inotify_add_watch 和 inotify_rm_watch。下面我们介绍一下这三个接口的作用和原型。
1. inotify_init
inotify_init 函数用于创建一个 inotify 的句柄,可以认为此句柄就是 inotify 的对象。其原型如下:
- int inotify_init(void);
2. inotify_add_watch
创建好 inotify 句柄后,就可以通过调用 inotify_add_watch 函数添加要进行监听的文件或者目录。其原型如下:
- int inotify_add_watch(int fd, const char *path, uint32_t mask);
inotify_add_watch 调用成功后,会返回被监听文件或目录的描述符。下面介绍一下各个参数的意义:
- fd:就是通过 inotify_init 函数创建的 inotify 句柄。
- path:要监听的文件或目录的路径。
- mask:要监听的事件,其事件类型如下:
类型 | 描述 |
---|---|
IN_ACCESS | 文件被访问 |
IN_ATTRIB | 文件元数据改变 |
IN_CLOSE_WRITE | 关闭为了写入而打开的文件 |
IN_CLOSE_NOWRITE | 关闭只读方式打开的文件 |
IN_CREATE | 在监听目录内创建了文件/目录 |
IN_DELETE | 在监听目录内删除文件/目录 |
IN_DELETE_SELF | 监听目录/文件本身被删除。 |
IN_MODIFY | 文件被修改 |
IN_MOVE_SELF | 受监控目录/文件本身被移动 |
IN_MOVED | 文件被移 |
IN_OPEN | 文件被打开 |
IN_ALL_EVENTS | 以上所有输出事件的统称 |
3. inotify_rm_watch
inotify_rm_watch 函数用于删除被监听的文件或目录,其原型如下:
- int inotify_rm_watch(int fd, uint32_t wd);
下面介绍一下各个参数的意义:
- fd:调用 inotify_init 函数返回的 inotify 句柄。
- wd:由 inotify_add_watch 函数的返回被监听文件或目录的描述符。
读取变动事件
介绍完 inotify 的接口后,现在通过一个简单的例子来展示怎么使用 inotify。在编写 inotify 的实例前,先介绍一下怎么获取被监听文件或目录的变动事件。inotify 并没有提供特定的接口来获取被监听的文件或目录的变动事件,而是通过通用的 read 函数来读取,我们来看看 read 函数的原型:
- int read(int fd, void *events, size_t len);
下面说说各个参数的意义:
- fd:由 inotify_init 创建的 inotify 句柄。
- events:存放变动事件的缓冲区。
- len:缓冲区的大小。
-