今天发现个可以检测系统文件完整性的shell脚本,自己试了下还可以吧,介绍给大家。
系统:centos 5.x
脚本内容:
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
如果只想看到错误的话,可以用下面这个命令:
md5sum -c fp.20141209202544.chksum |grep -v "OK"
本文向大家介绍Shell脚本实现Linux系统和进程资源监控,包括了Shell脚本实现Linux系统和进程资源监控的使用技巧和注意事项,需要的朋友参考一下 在服务器运维过程中,经常需要对服务器的各种资源进行监控,例如:CPU的负载监控,磁盘的使用率监控,进程数目监控等等,以在系统出现异常时及时报警,通知系统管理员。本文介绍在Linux系统下几种常见的监控需求及其shell脚本的编写。 文章目录:
本文向大家介绍shell脚本实现磁盘监控系统,包括了shell脚本实现磁盘监控系统的使用技巧和注意事项,需要的朋友参考一下 利用shell脚本实现每隔60秒磁盘内存数据监控 效果如图: 以上就是shell脚本实现磁盘监控系统的详细内容,更多关于shell 磁盘监控的资料请关注呐喊教程其它相关文章!
本文向大家介绍Shell脚本注册到Linux系统服务实例,包括了Shell脚本注册到Linux系统服务实例的使用技巧和注意事项,需要的朋友参考一下 注册一个系统服务,开机自启动. 1 脚本编写 #vim test.sh 2注册服务 3.删除服务
Linux文件管理从用户的层面介绍了Linux管理文件的方式。Linux有一个树状结构来组织文件。树的顶端为根目录(/),节点为目录,而末端的叶子为包含数据的文件。当我们给出一个文件的完整路径时,我们从根目录出发,经过沿途各个目录,最终到达文件。 我们可以对文件进行许多操作,比如打开和读写。在Linux文件管理相关命令中,我们看到许多对文件进行操作的命令。它们大都基于对文件的打开和读写操作。比如c
本文向大家介绍Linux下文件剪切的shell脚本实现代码,包括了Linux下文件剪切的shell脚本实现代码的使用技巧和注意事项,需要的朋友参考一下 需求描述 编写shell脚本实现Linux下不同目录(路径)之间的文件的剪切(移动)操作。 其中,文件移动之前所在的目录称为源目录,文件移动之后所在的目录称为目的目录。要求当源目录不存在、源目录下无文件及剪切文件成功时,均要在屏幕上输出相关的日志信
本文向大家介绍shell脚本实现文件锁功能,包括了shell脚本实现文件锁功能的使用技巧和注意事项,需要的朋友参考一下 1.背景 当多个进程可能会对同样的数据执行操作时,这些进程需要保证其它进程没有在操作,以免损坏数据。通常,这样的进程会使用一个“锁文件”,也就是建立一个文件来告诉别的进程自己在运行,如果检测到那个文件存在则认为有操作同样数据的进程在工作。这样的问题是,进程不小心意外死亡了,没有清