Linux命令 inotifywait - 異步文件系統(tǒng)監(jiān)控機(jī)制

2021-11-12 14:49 更新

inotifywait

異步文件系統(tǒng)監(jiān)控機(jī)制

補充說明

Inotify 一種強(qiáng)大的、細(xì)粒度的、異步文件系統(tǒng)監(jiān)控機(jī)制,它滿足各種各樣的文件監(jiān)控需要,可以監(jiān)控文件系統(tǒng)的訪問屬性、讀寫屬性、權(quán)限屬性、刪除創(chuàng)建、移動等操作,也就是可以監(jiān)控文件發(fā)生的一切變化。。

inotify-tools 是一個C庫和一組命令行的工作提供Linux下inotify的簡單接口。inotify-tools安裝后會得到inotifywait和inotifywatch這兩條命令:

  • inotifywait命令 可以用來收集有關(guān)文件訪問信息,Linux發(fā)行版一般沒有包括這個命令,需要安裝inotify-tools,這個命令還需要將inotify支持編譯入Linux內(nèi)核,好在大多數(shù)Linux發(fā)行版都在內(nèi)核中啟用了inotify。
  • inotifywatch命令 用于收集關(guān)于被監(jiān)視的文件系統(tǒng)的統(tǒng)計數(shù)據(jù),包括每個 inotify 事件發(fā)生多少次。

開始之前需要檢測系統(tǒng)內(nèi)核是否支持inotify:

使用uname -r命令檢查Linux內(nèi)核,如果低于2.6.13,就需要重新編譯內(nèi)核加入inotify的支持。

使用ll /proc/sys/fs/inotify命令,是否有以下三條信息輸出,如果沒有表示不支持。

ll /proc/sys/fs/inotify
total 0
-rw-r--r-- 1 root root 0 Jan  4 15:41 max_queued_events
-rw-r--r-- 1 root root 0 Jan  4 15:41 max_user_instances
-rw-r--r-- 1 root root 0 Jan  4 15:41 max_user_watches

安裝inotify-tools

  • inotify-tools項目地址:https://github.com/rvoicilas/inotify-tools
  • inotify-tools下載地址:http://github.com/downloads/rvoicilas/inotify-tools/inotify-tools-3.14.tar.gz
#CentOS release 5.8/64位:
tar zxvf inotify-tools-3.14.tar.gz
cd inotify-tools-3.14
./configure
make
make install

其他Linux發(fā)行版安裝方法可以參見:https://github.com/rvoicilas/inotify-tools/wiki#wiki-getting

inotify相關(guān)參數(shù)

inotify定義了下列的接口參數(shù),可以用來限制inotify消耗kernel memory的大小。由于這些參數(shù)都是內(nèi)存參數(shù),因此,可以根據(jù)應(yīng)用需求,實時的調(diào)節(jié)其大?。?/p>

  • /proc/sys/fs/inotify/max_queued_evnets表示調(diào)用inotify_init時分配給inotify instance中可排隊的event的數(shù)目的最大值,超出這個值的事件被丟棄,但會觸發(fā)IN_Q_OVERFLOW事件。
  • /proc/sys/fs/inotify/max_user_instances表示每一個real user id可創(chuàng)建的inotify instatnces的數(shù)量上限。
  • /proc/sys/fs/inotify/max_user_watches表示每個inotify instatnces可監(jiān)控的最大目錄數(shù)量。如果監(jiān)控的文件數(shù)目巨大,需要根據(jù)情況,適當(dāng)增加此值的大小。

根據(jù)以上在32位或者64位系統(tǒng)都可以執(zhí)行:

echo 104857600 > /proc/sys/fs/inotify/max_user_watches
echo 'echo 104857600 > /proc/sys/fs/inotify/max_user_watches' >> /etc/rc.local

如果遇到以下錯誤:

inotifywait: error while loading shared libraries: libinotifytools.so.0: cannot open shared object file: No such file or directory 
 **解決方法:** 
32位系統(tǒng):ln -s /usr/local/lib/libinotifytools.so.0 /usr/lib/libinotifytools.so.0
64位系統(tǒng):ln -s /usr/local/lib/libinotifytools.so.0 /usr/lib64/libinotifytools.so.0

inotifywait命令使用

#!/bin/bash
#filename watchdir.sh
path=$1
/usr/local/bin/inotifywait -mrq --timefmt '%d/%m/%y/%H:%M' --format '%T %w %f' -e modify,delete,create,attrib $path

執(zhí)行輸出:
./watchdir.sh /data/wsdata/tools/
04/01/13/16:34 /data/wsdata/tools/ .j.jsp.swp
04/01/13/16:34 /data/wsdata/tools/ .j.jsp.swx
04/01/13/16:34 /data/wsdata/tools/ .j.jsp.swx
04/01/13/16:34 /data/wsdata/tools/ .j.jsp.swp
04/01/13/16:34 /data/wsdata/tools/ .j.jsp.swp
04/01/13/16:34 /data/wsdata/tools/ .j.jsp.swp
04/01/13/16:34 /data/wsdata/tools/ .j.jsp.swp
04/01/13/16:34 /data/wsdata/tools/ .j.jsp.swp
04/01/13/16:35 /data/wsdata/tools/ 4913
04/01/13/16:35 /data/wsdata/tools/ 4913
04/01/13/16:35 /data/wsdata/tools/ 4913
04/01/13/16:35 /data/wsdata/tools/ j.jsp
04/01/13/16:35 /data/wsdata/tools/ j.jsp
04/01/13/16:35 /data/wsdata/tools/ j.jsp
04/01/13/16:35 /data/wsdata/tools/ j.jsp~
04/01/13/16:35 /data/wsdata/tools/ .j.jsp.swp

inotifywait命令參數(shù)

  • -m是要持續(xù)監(jiān)視變化。
  • -r使用遞歸形式監(jiān)視目錄。
  • -q減少冗余信息,只打印出需要的信息。
  • -e指定要監(jiān)視的事件列表。
  • --timefmt是指定時間的輸出格式。
  • --format指定文件變化的詳細(xì)信息。

可監(jiān)聽的事件

事件描述
access訪問 ,讀取文件。
modify修改 ,文件內(nèi)容被修改。
attrib屬性 ,文件元數(shù)據(jù)被修改。
move移動 ,對文件進(jìn)行移動操作。
create創(chuàng)建 ,生成新文件
open打開 ,對文件進(jìn)行打開操作。
close關(guān)閉 ,對文件進(jìn)行關(guān)閉操作。
delete刪除 ,文件被刪除。


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號