主頁 > 知識庫 > 一個監(jiān)控LINUX目錄和文件變化的Shell腳本分享

一個監(jiān)控LINUX目錄和文件變化的Shell腳本分享

熱門標簽:百度競價排名 Linux服務器 地方門戶網(wǎng)站 AI電銷 服務外包 呼叫中心市場需求 鐵路電話系統(tǒng) 網(wǎng)站排名優(yōu)化

最近看到群里有人聊到他們的服務器最近被掛馬,然后想利用一個腳本能夠?qū)崟r監(jiān)控web目錄下文件的變化,也就是對該目錄的增刪改操作都會記錄到相應日志下。

當時感覺這個功能的確實有點意思,所以網(wǎng)上查閱了些資料,自己研究了下,這會兒有空寫了個腳本,分享給大家,如有問題,還請大家指出。

以下我寫了兩個腳本:

腳本1:將需要監(jiān)控的目錄的原始狀態(tài)保存到LOG日志
腳本2:將腳本1的原始狀態(tài)與本腳本比對,如果目錄文件發(fā)生變化,則將變化的內(nèi)容保存到日志。

注:原理實際上利用的是du -sb輸出值來判斷文件的變化,再利用diff進行比對。

1.在執(zhí)行腳本前要保存原始的狀態(tài):

# vi initial.sh

復制代碼 代碼如下:

#!/bin/bash
PATH=/bin:/sbin:/usr/bin:/usr/sbin/:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
# 監(jiān)控的目錄
DIR=/root
# 臨時文件
TMP_A=/tmp/a.txt
# 遍歷指定目錄下的文件大小及路徑并重定向到日志文件
find $DIR -print0 | xargs -0 du -sb  > $TMP_A

2.執(zhí)行監(jiān)控腳本
# vi monitor.sh
復制代碼 代碼如下:

#!/bin/bash
PATH=/bin:/sbin:/usr/bin:/usr/sbin/:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
# 監(jiān)控的目錄
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
# 將當前監(jiān)控的目錄結(jié)構(gòu)覆蓋為初始狀態(tài)
       find $DIR -print0 | xargs -0 du -sb  > $TMP_A
   fi
fi
echo "====================================" >> $LOG
#清理臨時文件
rm -rf $TMP_B $TMP_C

您可能感興趣的文章:
  • Python中使用Inotify監(jiān)控文件實例
  • 使用Inotify 監(jiān)控目錄與文件的方法詳解
  • Linux 監(jiān)控文件被什么進程修改(詳解)
  • Linux inotify監(jiān)聽文件狀態(tài)的操作方法

標簽:湘潭 湖南 衡水 蘭州 銅川 崇左 仙桃 黃山

巨人網(wǎng)絡通訊聲明:本文標題《一個監(jiān)控LINUX目錄和文件變化的Shell腳本分享》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266