zoukankan      html  css  js  c++  java
  • linux怎么实时查看目录下是否有文件生成

    inotify-tools 是为linux下inotify文件监控工具提供的一套c的开发接口库函数,同时还提供了一系列的命令行工具,这些工具可以用来监控文件系统的事件。 inotify-tools是用c编写的,除了要求内核支持inotify外,不依赖于其他。inotify-tools提供两种工具,一是inotifywait,它是用来监控文件或目录的变化,二是inotifywatch,它是用来统计文件系统访问的次数

    安装inotify-tools

    $ sudo apt install inotify-tools -y

    创建数据和日志目录

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

    创建日志文件

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

    假设在 /tmp/inotify/data/ 中不断生成(删除,移动)数据,/tmp/inotify/log/data.log 文件中记录日志

    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,采用后台运行的方式记录日志

    # 监控后台运行并输出到文件

    $ 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/目录下的所有文件,重新生成字典文件(过程略)

    $ 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 统计该目录下各事件的调用次数。

    $ 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 文件系统取消挂载,之后不再监听此文件系统。
  • 相关阅读:
    poj2104 Kth-Number
    bzoj2120 数颜色
    hdu5145 NPY and girls
    bzoj2734 集合选数
    bzoj3732 NetWork
    bzoj2152 聪聪可可
    hdu2036(多边形面积)
    超大次幂思路
    hdu 2030 统计汉字个数
    Hibernate 配置文件与映射文件 总结
  • 原文地址:https://www.cnblogs.com/wpjamer/p/9916842.html
Copyright © 2011-2022 走看看