Linux 中有时需要配置事件触发的任务,在Linux kernel 2.6.13后提供了inotify文件系统监控机制,可以应用它实时完成工作。
简介 {#简介}
-
Inotify 是一个 Linux特性,它监控文件系统操作,比如读取、写入和创建。Inotify 反应灵敏,用法非常简单,并且比 cron 任务的繁忙轮询高效得多。
-
inotify 工具有:
inotify
、sersync
、lsyncd
。 -
sersync 是金山的周洋开发的工具,克服了 inotify的缺陷,且提供了几个插件作为可选工具。此处先介绍 inotify的用法以及它的缺, 通过其缺陷引出 sersync,并介绍其用法。
安装 inotify-tools {#安装-inotify-tools}
-
内核版本需要高于 2.6.13
可以用
uname -a
查看内核版本 -
下载链接: https://github.com/downloads/rvoicilas/inotify-tools/inotify-tools-3.14.tar.gz
-
下载安装:
-
在系统下执行
可得到相应的帮助信息,如果看到信息 则表示安装完成.
-
执行:
如果看到显示
max_queued_events
max_user_instances
max_user_watches
则说明支持inotify
相关配置 {#相关配置}
- 为命令创建软链:
- 安装后,可以在
/usr/local/bin
中看到两个文件,也就是 inotify-tools 工具提供的两个命令:
inotifywait: 用于等待文件发生变化,所以可以可以实现监控(watch)的功能,该命令是inotify的核心命令。
inotifywatch: 用于收集文件系统的统计数据,例如发生了多少次inotify事件,某文件被访问了多少次等等,一般用不上。
-
在
/proc/sys/fs/inotify
文件夹中有三个文件其中:
| 文件名 | 含义 | |--------------------|------------------------------------------------------------------------------------| | max_queued_events | 调用inotify_init时分配到inotify instance中可排队的event数的最大值,超出值时的事件被丢弃,但会触发队列溢出Q_OVERFLOW事件。 | | max_user_instances | 每一个real user可创建的inotify instances数量的上限 | | max_user_watches | 每个inotify实例相关联的watches的上限,即每个inotify实例可监控的最大目录、文件数量。如果监控的文件数目巨大,需要根据情况适当增加此值。 |
比如:
此处我们执行:
支持事件 {#支持事件}
inotify 可以监视的文件系统事件包括:
| 事件 | 含义 | |------------------|-----------------------------------------------------------| | IN_ACCESS | 即文件被访问 | | IN_MODIFY | 文件被 write | | IN_ATTRIB | 文件属性被修改, 如 chmod、chown、touch 等 | | IN_CLOSE_WRITE | 可写文件被 close,打开的文件被关闭,是为了写文件而打开文件,之后被关闭的事件 | | IN_CLOSE_NOWRITE | 不可写文件被 close,read only模式下文件被关闭,即只能是为了读取而打开文件,读取结束后关闭文件的事件 | | IN_OPEN | 文件被 open | | IN_MOVED_FROM | 文件被移走,如 mv | | IN_MOVED_TO | 文件被移来,如 mv、cp | | IN_MOVE | 是moved_to和moved_from的结合 | | IN_MOVE_SELF | 被监控的文件或目录发生了移动,移动结束后将不再监控此文件或目录 | | IN_CREATE | 创建新文件 | | IN_DELETE | 文件被删除 | | IN_DELETE_SELF | 自删除 | | IN_UNMOUNT | 挂载在被监控目录上的文件系统被umount,umount后不再监控此目录 | | IN_ISDIR | 监控目录相关操作 |
使用方法 {#使用方法}
inotifywait 命令的选项
| 参数 | 含义 |
|------------------------|--------------------------------------------------------------------|
| -m
| 表示始终监控,否则应该是监控到了一次就退出监控了 |
| -r
| 递归监控,监控目录中的任何文件,包括子目录。递归监控可能会超出max_user_watches的值,需要适当调整该值 |
| @<file>
| 如果是对目录进行递归监控,则该选项用于排除递归目录中不被监控的文件。file是相对路径还是绝对路径由监控目录是相对还是绝对来决定 |
| -q
| --quiet的意思,静默监控,这样就不会输出一些无关的信息 |
| -e
| 指定监控的事件。一般监控的就delete、create、attrib、modify、close_write |
| --exclude <pattern>
| 通过模式匹配来指定不被监控的文件,区分大小写 |
| --excludei <pattern>
| 通过模式匹配来指定不被监控的文件,不区分大小写 |
| --timefmt
| 监控到事件触发后,输出的时间格式,可指定可不指定该选项,一般设置为[--timefmt '%Y/%m/%d %H:%M:%S'] |
| --format
| 用户自定义的输出格式,如[--format '%w%f %e%T'] |
| %w
| 产生事件的监控路径,不一定就是发生事件的具体文件,例如递归监控一个目录,该目录下的某文件产生事件,将输出该目录而非其内具体的文件 |
| %f
| 如果监控的是一个目录,则输出产生事件的具体文件名。其他所有情况都输出空字符串 |
| %e
| 产生的事件名称 |
| %T
| 以"--timefmt"定义的时间格式输出当前时间,要求同时定义"--timefmt" |
使用示例 {#使用示例}
监控 close_write
事件 {#监控-close-write-事件}
其中/data/logs/file_change.log是日志路径,/data/htdocs是监控的网站路径
监控文件夹 {#监控文件夹}
以前台方式监控目录,由于没指定监控的事件,所以监控所有事件
创建文件 {#创建文件}
触发create、open attrib、close_write和close事件
创建目录 {#创建目录}
ISDIR表示产生该事件的对象是一个目录。
修改文件属性 {#修改文件属性}
触发attrib事件
cat查看文件 {#cat查看文件}
触发open、access、close_nowrite和close事件
追加或写入或清除数据 {#追加或写入或清除数据}
触发open、modify、close_write和close事件
vim打开文件并修改文件 {#vim打开文件并修改文件}
中间涉及到临时文件,所以有非常多的事件。
向目录中拷入一个文件 {#向目录中拷入一个文件}
触发create、open、modify和close_write、close事件。
删除一个文件 {#删除一个文件}
触发delete事件
参考资料 {#参考资料}
- https://www.cnblogs.com/f-ck-need-u/p/7220193.html
- https://blog.csdn.net/weixin_30951743/article/details/95062358
- https://www.bilibili.com/video/av30980577/
- https://baike.baidu.com/item/inotify/8361039?fr=aladdin
文章链接:
https://www.zywvvd.com/notes/system/linux/commands/inotify/inotify/