使用Inotify 監(jiān)控目錄與文件的方法詳解
更新時間:2013年05月27日 15:32:15 作者:
本篇文章是對使用Inotify 監(jiān)控目錄與文件的方法進行了詳細的分析介紹,需要的朋友參考下
1. 監(jiān)控路徑并打印所有發(fā)生在該路徑的事件.
代碼如下:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/inotify.h>
#include <unistd.h>
#define EVENT_NUM 12
char *event_str[EVENT_NUM] =
{
"IN_ACCESS",
"IN_MODIFY",
"IN_ATTRIB",
"IN_CLOSE_WRITE",
"IN_CLOSE_NOWRITE",
"IN_OPEN",
"IN_MOVED_FROM",
"IN_MOVED_TO",
"IN_CREATE",
"IN_DELETE",
"IN_DELETE_SELF",
"IN_MOVE_SELF"
};
int main(int argc, char *argv[])
{
int fd;
int wd;
int len;
int nread;
char buf[BUFSIZ];
struct inotify_event *event;
int i;
if(argc < 2)
{
fprintf(stderr, "%s path\n", argv[0]);
return -1;
}
fd = inotify_init();
if( fd < 0 )
{
fprintf(stderr, "inotify_init failed\n");
return -1;
}
wd = inotify_add_watch(fd, argv[1], IN_ALL_EVENTS);
if(wd < 0)
{
fprintf(stderr, "inotify_add_watch %s failed\n", argv[1]);
return -1;
}
buf[sizeof(buf) - 1] = 0;
while( (len = read(fd, buf, sizeof(buf) - 1)) > 0 )
{
nread = 0;
while( len > 0 )
{
event = (struct inotify_event *)&buf[nread];
for(i=0; i<EVENT_NUM; i++)
{
if((event->mask >> i) & 1)
{
if(event->len > 0)
fprintf(stdout, "%s --- %s\n", event->name, event_str[i]);
else
fprintf(stdout, "%s --- %s\n", " ", event_str[i]);
}
}
nread = nread + sizeof(struct inotify_event) + event->len;
len = len - sizeof(struct inotify_event) - event->len;
}
}
return 0;
}
運行 inotify_watch 監(jiān)控一個目錄:
$ ./inotify_watch test/
...
--- IN_OPEN
--- IN_CLOSE_NOWRITE
.tmp.swp --- IN_CREATE
.tmp.swp --- IN_OPEN
.tmp.swpx --- IN_CREATE
.tmp.swpx --- IN_OPEN
.tmp.swpx --- IN_CLOSE_WRITE
.tmp.swpx --- IN_DELETE
.tmp.swp --- IN_CLOSE_WRITE
.tmp.swp --- IN_DELETE
.tmp.swp --- IN_CREATE
.tmp.swp --- IN_OPEN
.tmp.swp --- IN_MODIFY
--- IN_OPEN
--- IN_CLOSE_NOWRITE
.tmp.swp --- IN_MODIFY
...
從上面的結(jié)果可以看到在 test 目錄中使用 vim 創(chuàng)建一個 tmp 文件, 產(chǎn)生很多的冗雜事件. 因此需要對監(jiān)控的事件做出小范圍的選擇而不是 IN_ALL_EVENTS .
2. IN_MOVE_SELF 和 IN_DELETE_SELF 事件
由于個人水平, 曾經(jīng)對這兩個事件的含義并沒有理解正確. 當(dāng)監(jiān)控 path 時( path可以是文件或目錄),
$ ./inotify_watch path
執(zhí)行
$ rm -f path
則發(fā)生 IN_DELETE_SELF 事件;
執(zhí)行
mv path path2
則發(fā)生 IN_MOVE_SELF 事件.
3. 監(jiān)控目錄和文件
監(jiān)控目錄中內(nèi)容改變應(yīng)監(jiān)控的事件:
IN_CREATE | IN_DELETE | IN_DELETE_SELF | IN_MODIFY | IN_MOVE_SELF | IN_MOVED_FROM | IN_MOVDED_TO
監(jiān)控文件內(nèi)容的改變應(yīng)監(jiān)控的事件:
IN_DELETE_SELF | IN_MODIFY | IN_MOVE_SELF
代碼如下:
復(fù)制代碼 代碼如下:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/inotify.h>
#include <unistd.h>
#define EVENT_NUM 12
char *event_str[EVENT_NUM] =
{
"IN_ACCESS",
"IN_MODIFY",
"IN_ATTRIB",
"IN_CLOSE_WRITE",
"IN_CLOSE_NOWRITE",
"IN_OPEN",
"IN_MOVED_FROM",
"IN_MOVED_TO",
"IN_CREATE",
"IN_DELETE",
"IN_DELETE_SELF",
"IN_MOVE_SELF"
};
int main(int argc, char *argv[])
{
int fd;
int wd;
int len;
int nread;
char buf[BUFSIZ];
struct inotify_event *event;
int i;
if(argc < 2)
{
fprintf(stderr, "%s path\n", argv[0]);
return -1;
}
fd = inotify_init();
if( fd < 0 )
{
fprintf(stderr, "inotify_init failed\n");
return -1;
}
wd = inotify_add_watch(fd, argv[1], IN_ALL_EVENTS);
if(wd < 0)
{
fprintf(stderr, "inotify_add_watch %s failed\n", argv[1]);
return -1;
}
buf[sizeof(buf) - 1] = 0;
while( (len = read(fd, buf, sizeof(buf) - 1)) > 0 )
{
nread = 0;
while( len > 0 )
{
event = (struct inotify_event *)&buf[nread];
for(i=0; i<EVENT_NUM; i++)
{
if((event->mask >> i) & 1)
{
if(event->len > 0)
fprintf(stdout, "%s --- %s\n", event->name, event_str[i]);
else
fprintf(stdout, "%s --- %s\n", " ", event_str[i]);
}
}
nread = nread + sizeof(struct inotify_event) + event->len;
len = len - sizeof(struct inotify_event) - event->len;
}
}
return 0;
}
運行 inotify_watch 監(jiān)控一個目錄:
復(fù)制代碼 代碼如下:
$ ./inotify_watch test/
...
--- IN_OPEN
--- IN_CLOSE_NOWRITE
.tmp.swp --- IN_CREATE
.tmp.swp --- IN_OPEN
.tmp.swpx --- IN_CREATE
.tmp.swpx --- IN_OPEN
.tmp.swpx --- IN_CLOSE_WRITE
.tmp.swpx --- IN_DELETE
.tmp.swp --- IN_CLOSE_WRITE
.tmp.swp --- IN_DELETE
.tmp.swp --- IN_CREATE
.tmp.swp --- IN_OPEN
.tmp.swp --- IN_MODIFY
--- IN_OPEN
--- IN_CLOSE_NOWRITE
.tmp.swp --- IN_MODIFY
...
從上面的結(jié)果可以看到在 test 目錄中使用 vim 創(chuàng)建一個 tmp 文件, 產(chǎn)生很多的冗雜事件. 因此需要對監(jiān)控的事件做出小范圍的選擇而不是 IN_ALL_EVENTS .
2. IN_MOVE_SELF 和 IN_DELETE_SELF 事件
由于個人水平, 曾經(jīng)對這兩個事件的含義并沒有理解正確. 當(dāng)監(jiān)控 path 時( path可以是文件或目錄),
復(fù)制代碼 代碼如下:
$ ./inotify_watch path
執(zhí)行
復(fù)制代碼 代碼如下:
$ rm -f path
則發(fā)生 IN_DELETE_SELF 事件;
執(zhí)行
復(fù)制代碼 代碼如下:
mv path path2
則發(fā)生 IN_MOVE_SELF 事件.
3. 監(jiān)控目錄和文件
監(jiān)控目錄中內(nèi)容改變應(yīng)監(jiān)控的事件:
復(fù)制代碼 代碼如下:
IN_CREATE | IN_DELETE | IN_DELETE_SELF | IN_MODIFY | IN_MOVE_SELF | IN_MOVED_FROM | IN_MOVDED_TO
監(jiān)控文件內(nèi)容的改變應(yīng)監(jiān)控的事件:
復(fù)制代碼 代碼如下:
IN_DELETE_SELF | IN_MODIFY | IN_MOVE_SELF
相關(guān)文章
matlab遺傳算法求解車間調(diào)度問題分析及實現(xiàn)源碼
這篇文章主要為大家介紹了matlab遺傳算法求解車間調(diào)度問題解析,文中附含詳細實現(xiàn)源碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-02-02淺談C++中的mutable和volatile關(guān)鍵字
下面小編就為大家?guī)硪黄獪\談C++中的mutable和volatile關(guān)鍵字。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06