使用MD5的檢測方法,shell指令碼實現linux系統檔案完整性檢測

eddy0lion發表於2018-01-10

今天發現個可以檢測系統檔案完整性的shell指令碼,自己試了下還可以吧,介紹給大家。
系統:centos 5.x
無中文指令碼如下:

點選(此處)摺疊或開啟

  1. #!/bin/bash

  2. shopt -s -o nounset
  3.  
  4. Date=$(date +'%Y%m%d%H%M%S')

  5.  
  6. Dirs="/bin /sbin /usr/bin /usr/sbin /lib /usr/local/sbin /usr/local/bin /usr/local/lib"

  7.  
  8. TMP_file=$(mktemp /tmp/check.XXXXXX)
  9.  

  10. FP="/root/fp.$Date.chksum"
  11.  

  12. Checker="/usr/bin/md5sum"
  13. Find="/usr/bin/find"

  14.  
  15. scan_file() {
  16.         local f
  17.         for f in $Dirs
  18.         do
  19.                 $Find $f -type f >> $TMP_file
  20.         done
  21. }
  22.  

  23. cr_checksum_list() {
  24.         local f
  25.         if [ -f $TMP_file ]; then
  26.                 for f in $(cat $TMP_file);
  27.                         do
  28.                                 $Checker $f >> $FP
  29.                 done
  30.         fi
  31. }
rmTMP() {
  1.         [ -f $TMP_file ] && rm -rf $TMP_file
  2. }

  3. scan_file
  4.  
  5. cr_checksum_list

  6. rmTMP
執行之後,只是獲得一個文字,現在開始正式檢測

指令碼執行:
[root@node3 ~]# sh my_filecheck.sh
進行校驗:
md5sum  -c fp.20141205160628.chksum
如果一切OK,都會顯示OK的字樣,如果有問題,就報相應的錯誤,如下:
[root@node3 ~]# md5sum  -c fp.20141205160628.chksum  | grep -v "OK"
md5sum: /usr/bin/chattr: No such file or directory
/usr/bin/chattr: FAILED open or read
md5sum: WARNING: 1 of 8267 listed files could not be read


我自己改寫了指令碼,增加了檢驗語句和輸出報錯,最後結尾顯示:
/usr/local/bin/dbhome: OK
/usr/local/bin/oraenv: OK
2018011017 echo error
2018011017 finsh


2018011017 echo error2018011017 finsh之間,會顯示有報錯的內容,如果沒有內容,就表示沒有報錯。
使用目錄,需提前建立
mkdir /root/scripts/log bin tmp
完整指令碼如下(時間改為精確到小時):

  1. #!/bin/bash

  2. source /etc/profile

  3. shopt -s -o nounset
  4.  
  5. Date=$(date +'%Y%m%d%H')
  6.  
  7. Dirs="/bin /sbin /usr/bin /usr/sbin /lib /usr/local/sbin /usr/local/bin /usr/local/lib"

  8.  
  9. TMP_file=$(mktemp /tmp/check.XXXXXX)
  10.  

  11. FP="/root/fp.$Date.chksum"
  12.  

  13. Checker="/usr/bin/md5sum"
  14. Find="/usr/bin/find"

  15.  
  16. scan_file() {
  17.         local f
  18.         for f in $Dirs
  19.         do
  20.                 $Find $f -type f >> $TMP_file
  21.         done
  22. }
  23.  

  24. cr_checksum_list() {
  25.         local f
  26.         if [ -f $TMP_file ]; then
  27.                 for f in $(cat $TMP_file);
  28.                         do
  29.                                 $Checker $f >> $FP
  30.                 done
  31.         fi
  32. }
  33. rmTMP() {
  34.         [ -f $TMP_file ] && rm -rf $TMP_file
  35. }

  36. scan_file
  37.  
  38. cr_checksum_list

  39. rmTMP

  40. Date=$(date +'%Y%m%d%H')
  41. FP="/root/fp.$Date.chksum"

  42. md5sum -c $FP >/root/scripts/log/$Date.log
  43. echo $Date "echo error">>/root/scripts/log/$Date.log
  44. md5sum -c $FP| grep -v "OK" >>/root/scripts/log/$Date.log
  45. echo $Date "finsh">>/root/scripts/log/$Date.log



以下可不看:


程式碼解釋如下:

cat my_filecheck.sh
#!/bin/bash
#
# 變數首先宣告才能使用
shopt -s -o nounset
 
# 宣告
 
# 建立日期
 
Date=$(date +'%Y%m%d%H%M%S')
 
# 加入稽核的目錄         #
 
Dirs="/bin /sbin /usr/bin /usr/sbin /lib /usr/local/sbin /usr/local/bin /usr/local/lib"
 
# 臨時檔案               #
 
TMP_file=$(mktemp /tmp/check.XXXXXX)
 
# 檔案checksum儲存檔案
FP="/root/fp.$Date.chksum"
 
# 使用哪種checksum工具
Checker="/usr/bin/md5sum"
Find="/usr/bin/find"
 
# 函式區                #
 
scan_file() {
        local f
        for f in $Dirs
        do
                $Find $f -type f >> $TMP_file
        done
}
 
# 讀取檔案建立每個檔案的checksum值
cr_checksum_list() {
        local f
        if [ -f $TMP_file ]; then
                for f in $(cat $TMP_file);
                        do
                                $Checker $f >> $FP
                done
        fi
}
rmTMP() {
        [ -f $TMP_file ] && rm -rf $TMP_file
}
 
 
# 主程式區
 
 
# 掃描列表
scan_file
 
# 建立檔案的checksum值
cr_checksum_list
 
# 清理臨時檔案
rmTMP


執行指令碼:



./my_filecheck.sh

進行校驗:


md5sum  -c fp.20141205160628.chksum

如下:


md5sum -c fp.20141209202544.chksum
/bin/gawk: OK
/bin/igawk: OK
/bin/ln: OK
/bin/loadkeys: OK
/bin/gzip: OK
/bin/mkdir: OK
/bin/date: OK
/bin/cat: OK
/bin/mountpoint: OK
/bin/taskset: OK
/bin/umount: OK
/bin/mount: OK
/bin/doexec: OK
/bin/kill: OK
/bin/sync: OK
/bin/unicode_start: OK
/bin/usleep: OK
/bin/mknod: OK
/bin/setserial: OK
/bin/cp: OK
/bin/mktemp: OK
/bin/setfont: OK
/bin/unicode_stop: OK
.....
/lib/modules/2.6.18-194.el5PAE/kernel/crypto/cast5.ko: OK
/lib/modules/2.6.18-194.el5PAE/kernel/crypto/crypto_blkcipher.ko: OK
/lib/modules/2.6.18-194.el5PAE/kernel/crypto/twofish.ko: OK
/lib/modules/2.6.18-194.el5PAE/kernel/crypto/authenc.ko: OK
/lib/modules/2.6.18-194.el5PAE/kernel/crypto/cbc.ko: OK
/lib/modules/2.6.18-194.el5PAE/kernel/crypto/crypto_hash.ko: OK
/lib/modules/2.6.18-194.el5PAE/kernel/crypto/seqiv.ko: OK
/lib/libproc-3.2.7.so: OK
/lib/libacl.so.1.1.0: OK
/lib/libauparse.so.0.0.0: OK
/lib/libdmraid.so.1.0.0.rc13-17: OK
/lib/libvolume_id.so.0.66.0: OK
/lib/libgobject-2.0.so.0.1200.3: OK
/lib/libnss_compat-2.5.so: OK
/lib/rtkaio/i686/nosegneg/librtkaio-2.5.so: OK
/lib/rtkaio/librtkaio-2.5.so: OK
/lib/libdmraid-events-isw.so.1.0.0.rc13: OK
/lib/libdevmapper-event-lvm2snapshot.so.2.02: OK
/lib/libblkid.so.1.0: OK
/lib/libdb-4.3.so: OK
/lib/libSegFault.so: OK
/lib/libiw.so.28: OK
/lib/libdmraid-events-isw.so.1.0.0.rc13-17: OK

可以看到很多OK.


如果只想看到錯誤的話,可以用下面這個命令:

複製程式碼 程式碼如下:

md5sum -c fp.20141209202544.chksum |grep -v "OK"

我的系統沒有報錯的,所以沒有辦法給大家結果.

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/28853590/viewspace-2150009/,如需轉載,請註明出處,否則將追究法律責任。

相關文章