快速业务通道

使用 inotify 监控文件系统的活动

作者 佚名技术 来源 Linux系统 浏览 发布时间 2012-05-10
管道线(|)操作符.如果 inotify_add_watch() 成功,该调用会为已注册的监视器返回一个惟一的标识符;否则,返回 -1.使用这个标识符更改或删除相关的监视器.
● inotify_rm_watch() 删除一个监视器.
此外,还需要 read() 和 close() 系统调用.如果描述符由 inotify_init() 生成,则调用 read() 等待警告.假设有一个典型的文件描述符,应用程序将阻塞对事件的接收,这些事件在流中表现为数据.文件描述符上的由 inotify_init() 生成的通用 close() 删除所有活动监视器,并释放与 inotify 实例相关联的所有内存(这里也用到典型的引用计数警告.与实例相关联的所有文件描述符在监视器和 inotify 消耗的内存被释放之前关闭).

这个强大的工具提供 3 个应用程序编程接口(API)调用,以及简单、熟悉的范例 “所有内容都是文件”.现在,我们看看示例应用程序.

示例应用程序:事件监控

清单 1 是一个监控两个事件的目录的简短 C 程序:文件的创建和删除.


清单 1. 简单的 inotify 应用程序,它监控创建、删除和修改事件的目录

#include <stdio.h>

#include <stdlib.h>

#include <errno.h>

#include <sys/types.h>

#include <sys/inotify.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];



  fd = inotify_init();



  if ( fd < 0 ) {

    perror( "inotify_init" );

  }



  wd = inotify_add_watch( fd, "/home/strike", 

                         IN_MODIFY | IN_CREATE | IN_DELETE );

  length = read( fd, buffer, BUF_LEN );  



  if ( length < 0 ) {

    perror( "read" );

  }  



  while ( i < length ) {

    struct inotify_event *event = ( struct inotify_event * ) &buffer[ i ];

    if ( event->len ) {

      if ( event->mask & IN_CREATE ) {

        if ( event->mask & IN_ISDIR ) {

          printf( "The directory %s was created.n", event->name );       

        }

        else {

          printf( "The file %s was created.n", event->name );

        }

      }

      else if ( event->mask & IN_DELETE ) {

        if ( event->mask & IN_ISDIR ) {

          printf( "The directory %s was deleted.n", event->name );       

        }

        else {

          printf( "The file %s was deleted.n", event->name );

        }

      }

      else if ( event->mask & IN_MODIFY ) {

        if ( event->mask & IN_ISDIR ) {

          printf( "The directory %s was modified.n", event->name );

        }

        else {

          printf( "The file %s was modified.n", event->name );

        }

      }

    }

    i  = EVENT_SIZE   event->len;

  }



  ( void ) inotify_rm_watch( fd, wd );

  ( void ) close( fd );



  exit( 0 );

}

这个应用程序通过 fd = inotify_init(); 创建一个 inotify 实例,并添加一个监视器来监控修改、新文件和 /home/strike 中的损坏文件(由 wd = inotify_add_watch(...) 指定).read() 方法在一个或多个警告到达之前是被阻塞的.警告的详细内容 — 每个文件、每个事件 — 是以字节流的形式发送的;因此,应用程序中的循环将字节流转换成一系列事件

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号