歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux基礎 >> 關於Linux >> 如何使用SHELL監控LINUX目錄文件變化

如何使用SHELL監控LINUX目錄文件變化

日期:2017/3/3 16:11:40   编辑:關於Linux

最近看到群裡有人聊到他們的服務器最近被掛馬,然後想利用一個腳本能夠實時監控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

--------------------

作者:51cto博客 一路向北

 

Copyright © Linux教程網 All Rights Reserved