用shell脚本实现企业日常巡检

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用shell脚本实现企业日常巡检相关的知识,希望对你有一定的参考价值。

#!/bin/bash

function system(){
echo "##########系统信息##########"
OS_TYPE=uname
OS_VER=cat /etc/redhat-release
OS_KER=uname -a|awk ‘{print $3}‘
OSTIME=`date +%F%T<br/>OS_RUN_TIME=uptime |awk ‘{print $3}‘|awk -F, ‘{print $1}‘<br/>OS_LAST_REBOOT_TIME=who -b|awk ‘{print $2,$3}‘<br/>OS_HOSTNAME=hostname`

echo " 系统类型:$OS_TYPE"
echo " 系统版本:$OS_VER"
echo " 系统内核:$OS_KER"
echo " 当前时间:$OS_TIME"
echo " 运行时间:$OS_RUN_TIME"
echo "最后重启时间:$OS_LAST_REBOOT_TIME"
echo " 本机名称:$OS_HOSTNAME"
}
function network(){

echo "############网络信息############"
INTERNET=(ifconfig|grep ens|awk -F: ‘{print $1}‘)
for((i=0;i<echo ${#INTERNET[*]};i++))
do
OS_IP=ifconfig ${INTERNET[$i]}|head -2|grep inet|awk ‘{print $2}‘
echo " 本机IP:${INTERNET[$i]}:$OS_IP"
done
curl -I http://www.baidu.com &>/dev/null
if [ $? -eq 0 ]
then echo " 访问外网:成功"
else echo " 访问外网:失败"
fi
}

function hardware(){

echo "##########硬件信息##########"
CPUID=grep "physical id" /proc/cpuinfo |sort|uniq|wc -l
CPUCORES=grep "cores" /proc/cpuinfo|sort|uniq|awk -F: ‘{print $2}‘
CPUMODE=grep "model name" /proc/cpuinfo|sort|uniq|awk -F: ‘{print $2}‘

echo " CPU数量: $CPUID"
echo " CPU核心:$CPUCORES"
echo " CPU型号:$CPUMODE"

MEMTOTAL=free -m|grep Mem|awk ‘{print $2}‘
MEMFREE=free -m|grep Mem|awk ‘{print $7}‘

echo " 内存总容量: ${MEMTOTAL}MB"
echo "剩余内存容量: ${MEMFREE}MB"

disksize=0
swapsize=free|grep Swap|awk {‘print $2‘}
partitionsize=(df -T|sed 1d|egrep -v "tmpfs|sr0"|awk {‘print $3‘})
for ((i=0;i<echo ${#partitionsize[*]};i++))
do
disksize=expr $disksize + ${partitionsize[$i]}
done
((disktotal=($disksize+$swapsize)/1024/1024))

echo " 磁盘总容量: ${disktotal}GB"

diskfree=0
swapfree=free|grep Swap|awk ‘{print $4}‘
partitionfree=(df -T|sed 1d|egrep -v "tmpfs|sr0"|awk ‘{print $5}‘)
for ((i=0;i<echo ${#partitionfree[*]};i++))
do
diskfree=expr $diskfree + ${partitionfree[$i]}
done

((freetotal=($diskfree+$swapfree)/1024/1024))

echo "剩余磁盘容量:${freetotal}GB"
}

function secure(){
echo "########安全信息##########"

countuser=(last|grep "still logged in"|awk ‘{print $1}‘|sort|uniq)
for ((i=0;i<echo ${#countuser[*]};i++))
do echo "当前登录用户:${countuser[$i]}"
done

md5sum -c --quiet /opt/passwd.db &>/dev/null
if [ $? -eq 0 ]
then echo " 用户异常:否"
else echo " 用户异常:是"
fi
}

function chksys(){
system
network
hardware
secure
}

以上是关于用shell脚本实现企业日常巡检的主要内容,如果未能解决你的问题,请参考以下文章

shell脚本——日常巡检脚本

日常巡检shell脚本

python结合shell脚本实现简单的日常集中巡检

精品Linux系统硬件网络系统及安全巡检邮箱告警脚本shell脚本

linux12企业实战 -- 40全网日常巡检

日常巡检脚本