linux怎麼實時查看目錄下是否有文件生成

inotify-tools 是爲linux下inotify文件監控工具提供的一套c的開發接口庫函數,同時還提供了一系列的命令行工具,這些工具能夠用來監控文件系統的事件。 inotify-tools是用c編寫的,除了要求內核支持inotify外,不依賴於其餘。inotify-tools提供兩種工具,一是inotifywait,它是用來監控文件或目錄的變化,二是inotifywatch,它是用來統計文件系統訪問的次數html

 

安裝inotify-tools

$ sudo apt install inotify-tools -y

 

建立數據和日誌目錄linux

$ sudo mkdir -p /tmp/inotify/log/ /tmp/inotify/data/

 

建立日誌文件git

$ touch /tmp/inotify/log/data.log

假設在 /tmp/inotify/data/ 中不斷生成(刪除,移動)數據,/tmp/inotify/log/data.log 文件中記錄日誌github

 

inotifywait -- 用來監控文件或目錄的變化

開啓監控 (這裏簡稱「會話1」)

$ inotifywait -mrq --timefmt '%y-%m-%d %H:%M' --format '%T %e %w%f' -e create -e delete -e move -e moved_to -e moved_from -e delete_self  /tmp/inotify/data/

再開一會話終端(這裏簡稱「會話2」),並切換到到 /tmp/inotify/data/ 目錄,咱們在裏面使用 Crunch 建立一些字典文件(或者你在裏面隨便建立,移動,刪除些什麼),不清楚 Crunch 是什麼,怎麼用的請參考《crunch--字典生成工具函數

$ cd /tmp/inotify/data/
$ crunch 5 5 -b 20mib -o START

 

這時,在會話1中會輸出工具

18-11-06 17:06 CREATE /tmp/inotify/data/START
18-11-06 17:06 MOVED_FROM /tmp/inotify/data/START
18-11-06 17:06 MOVED_TO /tmp/inotify/data/aaaaa-hqwmu.txt
18-11-06 17:06 CREATE /tmp/inotify/data/START
18-11-06 17:06 MOVED_FROM /tmp/inotify/data/START
18-11-06 17:06 MOVED_TO /tmp/inotify/data/hqwmv-phszp.txt
18-11-06 17:06 CREATE /tmp/inotify/data/START
18-11-06 17:06 MOVED_FROM /tmp/inotify/data/START
18-11-06 17:06 MOVED_TO /tmp/inotify/data/phszq-wypmk.txt
18-11-06 17:06 CREATE /tmp/inotify/data/START
18-11-06 17:06 MOVED_FROM /tmp/inotify/data/START
18-11-06 17:06 MOVED_TO /tmp/inotify/data/wypml-zzzzz.txt

 

後臺運行

Ctrl+C 在會話1中退出notifywait,採用後臺運行的方式記錄日誌post

# 監控後臺運行並輸出到文件ui

$ inotifywait -mrqd --timefmt '%y-%m-%d %H:%M' --format '%T %e %w%f' -e create -e delete -e move -e moved_to -e moved_from -e delete_self -o /tmp/inotify/log/data.log  /tmp/inotify/data/

刪除/tmp/inotify/data/目錄下的全部文件,從新生成字典文件(過程略)url

$ cat  /tmp/inotify/log/data.log

18-11-06 17:34 DELETE /tmp/inotify/data/aaaaa-hqwmu.txt
18-11-06 17:34 DELETE /tmp/inotify/data/hqwmv-phszp.txt
18-11-06 17:34 DELETE /tmp/inotify/data/phszq-wypmk.txt
18-11-06 17:34 DELETE /tmp/inotify/data/wypml-zzzzz.txt
18-11-06 17:34 CREATE /tmp/inotify/data/START
18-11-06 17:34 MOVED_FROM /tmp/inotify/data/START
18-11-06 17:34 MOVED_TO /tmp/inotify/data/aaaaa-hqwmu.txt
18-11-06 17:34 CREATE /tmp/inotify/data/START
18-11-06 17:34 MOVED_FROM /tmp/inotify/data/START
18-11-06 17:34 MOVED_TO /tmp/inotify/data/hqwmv-phszp.txt
18-11-06 17:34 CREATE /tmp/inotify/data/START
18-11-06 17:34 MOVED_FROM /tmp/inotify/data/START
18-11-06 17:34 MOVED_TO /tmp/inotify/data/phszq-wypmk.txt
18-11-06 17:34 CREATE /tmp/inotify/data/START
18-11-06 17:34 MOVED_FROM /tmp/inotify/data/START
18-11-06 17:34 MOVED_TO /tmp/inotify/data/wypml-zzzzz.txt

 

inotifywatch -- 用來統計文件系統訪問的次數

咱們依舊在 /tmp/inotify/data/ 目錄下執行 先刪除全部字典文件,再從新建立字典文件的操做。而後開啓 inotifywatch 統計該目錄下各事件的調用次數。spa

$ inotifywatch -v  -e create -e delete -e move -e moved_to -e moved_from -e delete_self -t 60 -r /tmp/inotify/data/

Establishing watches...
Setting up watch(es) on /tmp/inotify/data/
OK, /tmp/inotify/data/ is now being watched.
Total of 1 watches.
Finished establishing watches, now collecting statistics.
Will listen for events for 120 seconds.
total  moved_from  moved_to  create  delete  filename
16     4           4         4       4       /tmp/inotify/data/

 

參數說明

inotifywait

語法:

inotifywait [-hcmrq] [-e ] [-t ] [–format ] [–timefmt ] [ … ]

參數:

-h,–help
輸出幫助信息
@
排除不須要監視的文件,能夠是相對路徑,也能夠是絕對路徑。
–fromfile
從文件讀取須要監視的文件或排除的文件,一個文件一行,排除的文件以@開頭。
-m, –monitor
接收到一個事情而不退出,無限期地執行。默認的行爲是接收到一個事情後當即退出。
-d, –daemon
跟–monitor同樣,除了是在後臺運行,須要指定–outfile把事情輸出到一個文件。也意味着使用了–syslog。
-o, –outfile
輸出事情到一個文件而不是標準輸出。
-s, –syslog
輸出錯誤信息到系統日誌
-r, –recursive
監視一個目錄下的全部子目錄。
-q, –quiet
指定一次,不會輸出詳細信息,指定二次,除了致命錯誤,不會輸出任何信息。
–exclude
正則匹配須要排除的文件,大小寫敏感。
–excludei
正則匹配須要排除的文件,忽略大小寫。
-t , –timeout
設置超時時間,若是爲0,則無限期地執行下去。
-e , –event
指定監視的事件。
-c, –csv
輸出csv格式。
–timefmt
指定時間格式,用於–format選項中的%T格式。
–format
指定輸出格式。
%w 表示發生事件的目錄
%f 表示發生事件的文件
%e 表示發生的事件
%Xe 事件以「X」分隔
%T 使用由–timefmt定義的時間格式

 

inotifywatch

語法:

inotifywatch [-hvzrqf] [-e ] [-t ] [-a ] [-d ] [ … ]


參數:

-h, –help
輸出幫助信息
-v, –verbose
輸出詳細信息
@
排除不須要監視的文件,能夠是相對路徑,也能夠是絕對路徑。
–fromfile
從文件讀取須要監視的文件或排除的文件,一個文件一行,排除的文件以@開頭。
-z, –zero
輸出表格的行和列,即便元素爲空
–exclude
正則匹配須要排除的文件,大小寫敏感。
–excludei
正則匹配須要排除的文件,忽略大小寫。
-r, –recursive
監視一個目錄下的全部子目錄。
-t , –timeout
設置超時時間
-e , –event
只監聽指定的事件。
-a , –ascending
以指定事件升序排列。
-d , –descending
以指定事件降序排列。

 

可監聽事件

access 文件讀取
modify 文件更改。
attrib 文件屬性更改,如權限,時間戳等。
close_write 以可寫模式打開的文件被關閉,不表明此文件必定已經寫入數據。
close_nowrite 以只讀模式打開的文件被關閉。
close 文件被關閉,無論它是如何打開的。
open 文件打開。
moved_to 一個文件或目錄移動到監聽的目錄,即便是在同一目錄內移動,此事件也觸發。
moved_from 一個文件或目錄移出監聽的目錄,即便是在同一目錄內移動,此事件也觸發。
move 包括moved_to和 moved_from
move_self 文件或目錄被移除,以後再也不監聽此文件或目錄。
create 文件或目錄建立
delete 文件或目錄刪除
delete_self 文件或目錄移除,以後再也不監聽此文件或目錄
unmount 文件系統取消掛載,以後再也不監聽此文件系統。
相關文章
相關標籤/搜索