【bash】通过实践学习bash之检测局域网主机状态


【要求】

检测局域网下192,168.0.1~192.168.0.100之间所有主机的存活状态。并统计up和down主机的个数。

 【分析】

使用linux的ping命令进行检测

使用for循环获取所需检测的IP地址

用if语句进行结果判断并统计up和down主机个数

 【脚本】

  1. #!/bin/bash  
  2. ## Use ping command to check the network's PC state.  
  3.   
  4. network="192.168.0"  
  5. totalup=0  
  6. totaldown=0  
  7. for ipadd in $(seq 1 100)  
  8. do  
  9.         ping -c 1 -w 1 ${network}.${ipadd} &>/dev/null && result=0 || result=1  
  10.         if [ "$result" == 0 ]; then  
  11.                 echo "PC ${network}.${ipadd} is UP."  
  12.                 totalup=$((${totalup}+1))  
  13.         else  
  14.                 echo "PC ${network}.${ipadd} is DOWN."  
  15.                 totaldown=$((${totaldown}+1))  
  16.         fi  
  17. done  
  18. echo "The uping PC has ${totalup}"  
  19. echo "The downing PC has ${totaldown}"  

【心得】

首先将IP分割为192.168.0 和最后一位,通过for循环进行枚举。具体的1~100数值可通过bash内置命令seq来实现。

在ping命令进行判断时将stdout 和stderr丢弃,并且在成功ping通时将result进行赋值0,否侧将result赋值为1

通过if 语句进行result值的判断,统计up和down的主机个数,并输出。 

【扩展】

假设加入检测到主机down机后通过mail发送给管理员进行通知:

脚本如下:

  1. #!/bin/bash  
  2. ## Use ping command to check the network's PC state.  
  3.   
  4. network="192.168.0"  
  5. totalup=0  
  6. totaldown=0  
  7. for ipadd in $(seq 1 100)  
  8. do  
  9.         ping -c 1 -w 1 ${network}.${ipadd} &>/dev/null && result=0 || resul  
  10. t=1  
  11.         if [ "$result" == 0 ]; then  
  12.                 echo "PC ${network}.${ipadd} is UP."  
  13.                 totalup=$((${totalup}+1))  
  14.         else  
  15.                 echo "PC ${network}.${ipadd} is DOWN."  
  16.                 totaldown=$((${totaldown}+1))  
  17.                 echo -e "WARNNING:The PC (ip:${network}.${ipadd}) have down!!! \n `date`" | mail -s root 邮箱                    fi  
  18. done  
  19. echo "The uping PC has ${totalup}"  
  20. echo "The downing PC has ${totaldown}"  

然后可以在/etc/crontab中加入任务计划,比如每5分钟检测一次。

*/5 * * * *    (脚本绝对路径)

相关内容