使用MD5的檢測方法,shell指令碼實現linux系統檔案完整性檢測
今天發現個可以檢測系統檔案完整性的shell指令碼,自己試了下還可以吧,介紹給大家。
系統:centos 5.x
無中文指令碼如下:
點選(此處)摺疊或開啟
-
#!/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)
-
-
-
FP="/root/fp.$Date.chksum"
-
-
-
Checker="/usr/bin/md5sum"
-
Find="/usr/bin/find"
-
-
-
scan_file() {
-
local f
-
for f in $Dirs
-
do
-
$Find $f -type f >> $TMP_file
-
done
-
}
-
-
-
cr_checksum_list() {
-
local f
-
if [ -f $TMP_file ]; then
-
for f in $(cat $TMP_file);
-
do
-
$Checker $f >> $FP
-
done
-
fi
-
}
-
[ -f $TMP_file ] && rm -rf $TMP_file
-
}
-
-
scan_file
-
-
cr_checksum_list
-
- 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 error與2018011017 finsh之間,會顯示有報錯的內容,如果沒有內容,就表示沒有報錯。
使用目錄,需提前建立
mkdir /root/scripts/log bin tmp
完整指令碼如下(時間改為精確到小時):
-
#!/bin/bash
-
-
source /etc/profile
-
-
shopt -s -o nounset
-
-
Date=$(date +'%Y%m%d%H')
-
-
Dirs="/bin /sbin /usr/bin /usr/sbin /lib /usr/local/sbin /usr/local/bin /usr/local/lib"
-
-
-
TMP_file=$(mktemp /tmp/check.XXXXXX)
-
-
-
FP="/root/fp.$Date.chksum"
-
-
-
Checker="/usr/bin/md5sum"
-
Find="/usr/bin/find"
-
-
-
scan_file() {
-
local f
-
for f in $Dirs
-
do
-
$Find $f -type f >> $TMP_file
-
done
-
}
-
-
-
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
-
-
cr_checksum_list
-
-
rmTMP
-
-
Date=$(date +'%Y%m%d%H')
-
FP="/root/fp.$Date.chksum"
-
-
md5sum -c $FP >/root/scripts/log/$Date.log
-
echo $Date "echo error">>/root/scripts/log/$Date.log
-
md5sum -c $FP| grep -v "OK" >>/root/scripts/log/$Date.log
- 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/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 利用SHELL指令碼實現檔案完整性檢測程式(1.2版更新)指令碼
- 利用Tripwire檢測系統完整性
- Oracle recover後如何檢測檔案的完整性Oracle
- oracle 檢測指令碼on linuxOracle指令碼Linux
- CentOS 6 系統優化檢測指令碼CentOS優化指令碼
- 【shell 指令碼】檢視*.gz 檔案的內容指令碼
- 通過shell指令碼檢測MySQL服務資訊指令碼MySql
- Bash 指令碼實現每次登入到 Shell 時可以檢視 Linux 系統資訊指令碼Linux
- 異常值檢測!最佳統計方法實踐(程式碼實現)!⛵
- Linux系統檢查指令碼Linux指令碼
- iOS文字檔案的編碼檢測iOS
- 使用shell指令碼檢測資料庫連線訪問情況指令碼資料庫
- shell檢測檔案是windows格式還是unixWindows
- 入侵檢測系統分析及其在Linux下的實現(轉)Linux
- JavaScript人臉檢測的實現方法JavaScript
- 檢測檔案編碼,轉換檔案編碼
- iozone 一個檔案系統的效能檢測工具。
- 檢測不同伺服器上程式碼差別的shell的指令碼伺服器指令碼
- 微信域名檢測官方介面 微信域名實時檢測系統
- 檢測mysql狀態的指令碼MySql指令碼
- Linux 系統健康巡檢指令碼Linux指令碼
- 根據ip列表檢測主機狀態(shell指令碼)指令碼
- 使用shell指令碼巧妙統計檔案指令碼
- 微信域名檢測線上批次檢測如何實現?——利用域名檢測api介面實現批次檢測工具教程API
- 忽略檢測png檔案
- 檢測檔案到末尾
- Linux系統配置檔案簡易shell備份指令碼Linux指令碼
- 系統巡檢指令碼指令碼
- C#自動檢測檔案的編碼C#
- 微信qq域名檢測系統的使用教程
- 檢測真實的檔案型別函式型別函式
- Linux 檢視系統檔案命令Linux
- 欄位型別檢測指令碼型別指令碼
- 在Linux中,如何檢視和審計系統日誌檔案以檢測異常活動?Linux
- windows10系統使用自帶記憶體檢測工具檢測記憶體好壞的方法Windows記憶體
- 快速檢視LINUX 系統硬體的指令碼Linux指令碼
- 準實時異常檢測系統
- Linux中系統狀態檢測命令Linux