文件监控工具——inotify-tools使用

2024-06-14 03:04

本文主要是介绍文件监控工具——inotify-tools使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在做灰盒测试和恶意程序分析的时候,经常需要寻找创建、删除、修改的文件,而在无法确定操作的文件或生成的文件路径时,就需要用到可以监控文件和目录的工具了。比如测试任意文件上传时,文件名被改为随机字符串且HTTP响应中不返回文件路径;通过写文件的payload批量测试无回显命令注入漏洞;测试缓冲区溢出漏洞或拒绝服务漏洞时,可能会生成一些dump文件;这些测试场景下使用文件监控工具总比一直手动执行ls命令要好吧。

简介

inotify-tools是用C编写的,除了要求内核支持inotify外,不依赖于其他库。它提供了一套C开发接口库函数,使得开发者可以在自己的应用程序中集成文件系统监控功能。这些工具可以通过命令行或脚本使用,提供了灵活的监控选项和输出格式。inotify-tools 主要提供了两个命令行工具:inotifywaitinotifywatch

inotifywait的功能

  • 用于监控文件或目录的变化,如访问、写入、修改、删除等。
  • 可以实时监控指定目录或文件系统的所有事件。
  • 支持递归监控,即监控整个目录树的变化。
  • 可以指定监控特定类型的事件,如创建、删除、修改等。
  • 可以设置超时时间,如果在指定时间内没有事件发生,则退出。
  • 可以持续监控,直到手动停止或发生特定事件后退出。
  • 可以将监控结果输出到标准输出、文件或syslog。

inotifywatch的功能

  • 用于统计文件系统访问的次数和类型。
  • 可以收集关于被监视的文件系统的统计数据,如每个inotify事件发生的次数。
  • 适合用于分析文件系统的使用情况。

GitHub地址:https://github.com/inotify-tools/inotify-tools

安装

可以使用包管理器或通过源码安装。

包管理器安装

Debian/Ubuntu

sudo apt-get install inotify-tools

Centos

sudo yum install epel-release
sudo yum install inotify-tools

源码安装

  1. 克隆仓库到本地机器:git clone https://github.com/inotify-tools/inotify-tools.git
  2. 进入仓库目录:cd inotify-tools
  3. 自动创建config脚本:./autogen.sh
  4. 配置构建系统:./configure
  5. 编译源代码:make
  6. 安装库和头文件到系统路径(可能需要 sudo):sudo make install

或者直接执行:./build_and_test.sh

使用教程

notifywait 基本用法

inotifywait 命令用于等待文件系统上的特定事件。以下是一些常用的选项:

  • -m--monitor:持续监控,而不是在第一个事件发生后就退出。
  • -r--recursive:递归监控,监视指定目录及其所有子目录。
  • -e--event:指定要监控的事件类型,如 createdeletemodifyaccess 等。
  • -t--timeout:设置超时时间,单位为秒。

使用示例:inotifywait -m -r -e create,modify /root

这个命令会递归监控 /root 目录,输出所有创建和修改事件,并持续监控。

inotifywatch 基本用法

inotifywatch 命令用于收集和显示文件系统事件的统计信息。以下是一些常用的选项:

  • -r--recursive:递归监控指定目录及其所有子目录。
  • -e--event:指定要监控的事件类型。

使用示例:inotifywatch -r -e create,modify /root

这个命令会递归监控 /root 目录,并显示所有创建和修改事件的统计信息。

FAQ

直接监控根目录时,超出了系统允许的每个用户可以监视的 inotify 事件的数量上限,会发生错误:

Failed to watch /; upper limit on inotify watches reached!Please increase the amount of inotify watches allowed per user via `/proc/sys/fs/inotify/max_user_watches'.

要解决这个问题,需要增加每个用户允许的 inotify 监视器的数量:

  1. 查看当前的限制:cat /proc/sys/fs/inotify/max_user_watches
  2. 增加限制(例如,增加到65536):echo 65536 | sudo tee /proc/sys/fs/inotify/max_user_watches

此时不再报错:

作为C库使用

inotify-tools安装成功后,系统存在/usr/local/include/inotifytools/inotifytools.h文件,根据inotifytools.h头文件内容,inotifytools 库提供了一套丰富的函数来处理 inotify 事件。这些函数包括但不限于:

  1. 字符串和事件相互转换的函数,如 inotifytools_str_to_eventinotifytools_event_to_str
  2. 设置和获取监视的文件名,如 inotifytools_set_filename_by_wdinotifytools_filename_from_watch
  3. 监视文件和目录的函数,如 inotifytools_watch_fileinotifytools_watch_recursively
  4. 处理 inotify 事件的函数,如 inotifytools_next_eventinotifytools_next_events
  5. 错误处理和统计信息获取的函数,如 inotifytools_errorinotifytools_get_stat_by_wd
  6. 格式化输出 inotify 事件的函数,如 inotifytools_printfinotifytools_snprintf

示例代码:
test.c

#include <inotifytools/inotifytools.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/inotify.h> // 确保包含标准的 inotify 头文件#ifndef IN_ALL_EVENTS
#define IN_ALL_EVENTS (IN_CREATE | IN_DELETE | IN_MODIFY | IN_MOVED_FROM | IN_MOVED_TO)
#endifint main(int argc, char *argv[]) {if (argc < 2) {fprintf(stderr, "Usage: %s <directory-to-watch>\n", argv[0]);exit(EXIT_FAILURE);}const char *directory_to_watch = argv[1];int fd;// 初始化 inotifyif (inotifytools_init(0, 0, 0) < 0) {perror("inotifytools_init");exit(EXIT_FAILURE);}// 递归监视目录int wd = inotifytools_watch_recursively(directory_to_watch, IN_ALL_EVENTS);if (wd < 0) {perror("inotifytools_watch_recursively");inotifytools_cleanup();exit(EXIT_FAILURE);}printf("Watching %s for all events.\n", directory_to_watch);while (1) {// 获取下一个事件struct inotify_event *event = inotifytools_next_event(-1);if (event == NULL) {if (inotifytools_error() != 0) {perror("Error occurred while waiting for events");}break;}// 处理事件if (event->mask & IN_CREATE) {printf("File created: %s\n", event->name);}if (event->mask & IN_DELETE) {printf("File deleted: %s\n", event->name);}// 可以添加更多的事件处理// 假设 inotifytools_next_event 分配了事件结构,这里可能需要释放// 如果 inotifytools 提供了释放事件的函数,例如 inotifytools_free_event// inotifytools_free_event(event);}// 移除监视并清理 inotifyinotifytools_remove_watch_by_wd(wd);inotifytools_cleanup();return 0;
}

编译:gcc -o test test.c -linotifytools
执行:./test /tmp

原文地址:文件监控工具——inotify-tools使用

这篇关于文件监控工具——inotify-tools使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1059198

相关文章

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

Golang使用minio替代文件系统的实战教程

《Golang使用minio替代文件系统的实战教程》本文讨论项目开发中直接文件系统的限制或不足,接着介绍Minio对象存储的优势,同时给出Golang的实际示例代码,包括初始化客户端、读取minio对... 目录文件系统 vs Minio文件系统不足:对象存储:miniogolang连接Minio配置Min

使用Python绘制可爱的招财猫

《使用Python绘制可爱的招财猫》招财猫,也被称为“幸运猫”,是一种象征财富和好运的吉祥物,经常出现在亚洲文化的商店、餐厅和家庭中,今天,我将带你用Python和matplotlib库从零开始绘制一... 目录1. 为什么选择用 python 绘制?2. 绘图的基本概念3. 实现代码解析3.1 设置绘图画

Python pyinstaller实现图形化打包工具

《Pythonpyinstaller实现图形化打包工具》:本文主要介绍一个使用PythonPYQT5制作的关于pyinstaller打包工具,代替传统的cmd黑窗口模式打包页面,实现更快捷方便的... 目录1.简介2.运行效果3.相关源码1.简介一个使用python PYQT5制作的关于pyinstall

使用Python实现大文件切片上传及断点续传的方法

《使用Python实现大文件切片上传及断点续传的方法》本文介绍了使用Python实现大文件切片上传及断点续传的方法,包括功能模块划分(获取上传文件接口状态、临时文件夹状态信息、切片上传、切片合并)、整... 目录概要整体架构流程技术细节获取上传文件状态接口获取临时文件夹状态信息接口切片上传功能文件合并功能小

Golang使用etcd构建分布式锁的示例分享

《Golang使用etcd构建分布式锁的示例分享》在本教程中,我们将学习如何使用Go和etcd构建分布式锁系统,分布式锁系统对于管理对分布式系统中共享资源的并发访问至关重要,它有助于维护一致性,防止竞... 目录引言环境准备新建Go项目实现加锁和解锁功能测试分布式锁重构实现失败重试总结引言我们将使用Go作

Linux使用nohup命令在后台运行脚本

《Linux使用nohup命令在后台运行脚本》在Linux或类Unix系统中,后台运行脚本是一项非常实用的技能,尤其适用于需要长时间运行的任务或服务,本文我们来看看如何使用nohup命令在后台... 目录nohup 命令简介基本用法输出重定向& 符号的作用后台进程的特点注意事项实际应用场景长时间运行的任务服

Python3中Sanic中间件的使用

《Python3中Sanic中间件的使用》Sanic框架中的中间件是一种强大的工具,本文就来介绍Python3中Sanic中间件的使用,具有一定的参考价值,感兴趣的可以了解一下... 目录Sanic 中间件的工作流程中间件的使用1. 全局中间件2. 路由中间件3. 异常处理中间件4. 异步中间件5. 优先级

SpringBoot使用注解集成Redis缓存的示例代码

《SpringBoot使用注解集成Redis缓存的示例代码》:本文主要介绍在SpringBoot中使用注解集成Redis缓存的步骤,包括添加依赖、创建相关配置类、需要缓存数据的类(Tes... 目录一、创建 Caching 配置类二、创建需要缓存数据的类三、测试方法Spring Boot 熟悉后,集成一个外

Redis分布式锁使用及说明

《Redis分布式锁使用及说明》本文总结了Redis和Zookeeper在高可用性和高一致性场景下的应用,并详细介绍了Redis的分布式锁实现方式,包括使用Lua脚本和续期机制,最后,提到了RedLo... 目录Redis分布式锁加锁方式怎么会解错锁?举个小案例吧解锁方式续期总结Redis分布式锁如果追求