工作中经常遇到需要一下ping上千个IP的情况。于是参照网上其他人的成果,稍加改造,最终有了这个脚本:
#!/bin/bash
for i in `cat $1`
do
ping=`ping -c 1 -w 1 $i|grep loss|awk '{print $6}'|awk -F "%" '{print $1}'`
if (( $ping == 100 ));then
echo -e ping "\t" $i "\t" "\033[41;37m FAIL \033[0m"
elif (( $ping == 0 ));then
echo -e ping "\t" $i "\t" "\033[42;37m OK \033[0m"
else
echo -e ping "\t" $i "\t" "\033[44;37m NULL \033[0m"
fi
done
保存后 chmod 一下,在后面追加包含IP列表的文件即可。
上面的脚本是大概一年前写的,当时因为自己水平有限,所以废了不少功夫,后来随着知识增长,对解决这个问题有了新的认识,就是使用命令本身的返回状态。所以在这里更新一下:
#!/bin/bash
for i in `cat $1`
do
ping -c 1 -w 1 $i &>/dev/null &&\
echo -e ping "\t" $i "\t" "\033[42;37m OK \033[0m" ||\
echo -e ping "\t" $i "\t" "\033[41;37m FAILED \033[0m"
done
默认情况下,ping的超时时间比较长,这里使用-w参数设置为1秒,FAIL 和 OK的地方加上颜色显示,方便肉眼观察~