iis服务器助手广告广告
返回顶部
首页 > 资讯 > 操作系统 >一个监控LINUX目录和文件变化的Shell脚本分享
  • 378
分享到

一个监控LINUX目录和文件变化的Shell脚本分享

脚本文件目录 2022-06-04 21:06:09 378人浏览 独家记忆
摘要

最近看到群里有人聊到他们的服务器最近被挂马,然后想利用一个脚本能够实时监控WEB目录下文件的变化,也就是对该目录的增删改操作都会记录到相应日志下。 当时感觉这个功能的确实有点意思,所以网上查阅了些资料,自己

最近看到群里有人聊到他们的服务器最近被挂马,然后想利用一个脚本能够实时监控WEB目录下文件的变化,也就是对该目录的增删改操作都会记录到相应日志下。

当时感觉这个功能的确实有点意思,所以网上查阅了些资料,自己研究了下,这会儿有空写了个脚本,分享给大家,如有问题,还请大家指出。

以下我写了两个脚本:

脚本1:将需要监控的目录的原始状态保存到LOG日志
脚本2:将脚本1的原始状态与本脚本比对,如果目录文件发生变化,则将变化的内容保存到日志。

注:原理实际上利用的是du -sb输出值来判断文件的变化,再利用diff进行比对。

1.在执行脚本前要保存原始的状态:

# vi initial.sh

#!/bin/bash

PATH=/bin:/sbin:/usr/bin:/usr/sbin/:/usr/local/bin:/usr/local/sbin:~/bin

export PATH

# 监控的目录

DIR=/root

# 临时文件

TMP_A=/tmp/a.txt

# 遍历指定目录下的文件大小及路径并重定向到日志文件

find $DIR -print0 | xargs -0 du -sb  > $TMP_A

2.执行监控脚本
# vi monitor.sh
#!/bin/bash

PATH=/bin:/sbin:/usr/bin:/usr/sbin/:/usr/local/bin:/usr/local/sbin:~/bin

export PATH

# 监控的目录

DIR=/root

# 日期变量

DATE=`date +%F_%H:%M`

# 临时文件

TMP_A=/tmp/a.txt

TMP_B=/tmp/b.txt

TMP_C=/tmp/c.txt

# 日志文件

LOG=/var/log/filemodify.log

# 遍历指定目录下的文件大小及路径并重定向到日志文件

find $DIR -print0 | xargs -0 du -sb  > $TMP_B

# 比较目录变化,并将变化的文件写入日志

DIFF=$(diff $TMP_A $TMP_B)

if [[ -z $DIFF ]];

 then

   echo "Nothing change" >> $LOG

 else

   echo "Here is the change" >> $LOG

   echo "" >> $LOG

   echo "$DIFF" |awk '{print $3}'|sort -k2n |uniq |sed '/^$/d' |tee $TMP_C >> $LOG

   if [ -s $TMP_C ];

     then

       echo "" >> $LOG

       echo "It modified at $DATE" >> $LOG

# 将当前监控的目录结构覆盖为初始状态

       find $DIR -print0 | xargs -0 du -sb  > $TMP_A

   fi

fi

echo "====================================" >> $LOG

#清理临时文件

rm -rf $TMP_B $TMP_C

--结束END--

本文标题: 一个监控LINUX目录和文件变化的Shell脚本分享

本文链接: https://www.lsjlt.com/news/18220.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何编写一个监控LINUX目录和文件变化的Shell脚本
    本篇内容主要讲解“如何编写一个监控LINUX目录和文件变化的Shell脚本”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何编写一个监控LINUX目录和文件变化的Shell脚本”吧!脚本1:将需...
    99+
    2023-06-09
  • linux下进程监控的shell脚本分享
    这篇文章主要介绍“linux下进程监控的shell脚本分享”,在日常操作中,相信很多人在linux下进程监控的shell脚本分享问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”linux下进程监控的shell脚...
    99+
    2023-06-09
  • Shell脚本如何监控目录内文件改动
    这篇文章将为大家详细讲解有关Shell脚本如何监控目录内文件改动,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体代码如下所示:#! /bin/bashwebroot="/home/w...
    99+
    2023-06-09
  • 使用iconv批量改变文件编码的shell脚本分享
    这篇文章主要介绍“使用iconv批量改变文件编码的shell脚本分享”,在日常操作中,相信很多人在使用iconv批量改变文件编码的shell脚本分享问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”使用iconv...
    99+
    2023-06-09
  • 如何用Shell脚本统计当前目录下目录和文件的数量
    这篇文章主要讲解了“如何用Shell脚本统计当前目录下目录和文件的数量”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何用Shell脚本统计当前目录下目录和文件的数量”吧!下面用shell写...
    99+
    2023-06-09
  • java 使用线程监控文件目录变化的实现方法
    java 使用线程监控文件目录变化的实现方法  由于某种特殊的需求、弄了个使用线程监控文件目录变化的代码基本如下、其中减去一些复杂的操作、只留下基本代码:package com.file;import java.io.File;i...
    99+
    2023-05-31
    java 线程 监控
  • 如何使用rsync备份文件/目录到Linux服务器上的Shell脚本
    这篇文章将为大家详细讲解有关如何使用rsync备份文件/目录到Linux服务器上的Shell脚本,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。使用该脚本会以交互的方式实施备份,你需要提供远程...
    99+
    2023-06-28
  • 如何用linux批量备份服务器配置文件和目录的脚本
    本篇内容介绍了“如何用linux批量备份服务器配置文件和目录的脚本”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!功能:1. 只在备份机执行,...
    99+
    2023-06-09
  • 如何解决shell脚本中执行时提示“没有那个文件或目录”的问题
    本篇内容主要讲解“如何解决shell脚本中执行时提示“没有那个文件或目录”的问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何解决shell脚本中执行时提示“没有那个文件或目录”的问题”吧!...
    99+
    2023-06-09
  • linux如何改变一个目录的所有人属性并同时改变改目录下所有文件的属性
    ...
    99+
    2024-04-02
  • 怎么删除Linux一个目录下部分类型之外的所有文件
    这篇文章主要介绍怎么删除Linux一个目录下部分类型之外的所有文件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!有的时候,你可能会遇到这种情况,你需要删除一个目录下的所有文件,或者只是简单的通过删除除了一些指定类型(...
    99+
    2023-06-16
  • linux如何将几个文件和目录同时压缩成一个zip格式的压缩包
    ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作