工作中因需要监测现场网关设备到服务器之间的网络延时及丢包情况,该网关设备为arm-Linux内核,仅能支持基本的ping功能,ping包结果无法带上时间戳。因此写了以下一个简单的脚本。
#!/bin/sh
#系统启动20s后再执行脚本命令
sleep 20
#-------------------------
server_ip=114.114.114.114
#-------------------------
while [ true ]
do
#延时初始赋值为8s
latency="8000 ms"
#执行ping并获取结果,ping 1次,timeout设置为3s
str=$(ping "$server_ip" -c 1 -W 3)
#对ping结果的字符串进行截取,截取字符串最后的时延数据,即最后一个“/”字符右边的数据
nstr=${str##*/}
#获取截取的字符串的长度,如果上述的ping超时,则返回结果没有“/”字符,
#也即上述的截取操作得到的还是原字符串,长度超过20
nstrLen=${#nstr}
if [ $nstrLen -ge 20 ];then
#如果ping超时,则把延时标记为5000ms(当然也可以直接赋值为 "timeout")
latency="5000 ms"
else
#如果ping通,则上述截取得到的字符串即为ping延时。每个隔1s ping一次
latency=$nstr
sleep 1s
fi
#ping结果写入文件,并加上时间戳。>> 为“追加”方式写入
time=$(date "+%Y/%m/%d_%H:%M:%S")
echo "$time"" ""$latency" >>"ping".log
done
上述shell脚本文件可设置为开机自启动。方法一般是将该脚本执行命令写入 /etc/rc.local 文件,便可开机自动执行该ping包脚本(不同的linux内核可能存在区别)。