解释:
遍历读取一个包含IP
地址的文件,如该文件名为:ip.txt
,然后对该文件里的每行IP
地址执行ping
操作,并检查丢包率。如果ping
的丢包率为:100%,则输出该IP
不可达的日志;如果ping
的丢包率不为100%,则输出该IP
可达的日志。
#!/bin/bash
# 获取当前系统时间
current_time=$(date +"%Y-%m-%d-%H:%M:%S")
# 获取开始时间戳
start_time=$(date +%s)
for i in `cat ip.txt` # 逐个读取该文件里全部所列出的IP地址
do
ping=`ping -c 4 $i | grep loss | awk '{print $6}' | awk -F "%" '{print $1}'`
# ping的这一行是对读出来的ip ping 4次,看是否ping通。并取出loss的百分比的值,也就是丢包的值,看是否丢包
Packet_Loss_Rate=`ping -c 4 $i | grep loss | awk '{print $6}'`
if [ $ping -eq 100 ];then
# 比较一下,看丢包的值是否为100,如果是100就是全部丢包,那就是没ping通,则显示 IP ping 失败了;如果不等于100的话,就ping通了,则显示 IP ping 成功了。
echo "$current_time IP 地址:$i ping 失败了,丢包率为:$Packet_Loss_Rate" >>/opt/jacktian/ip.txt_ping.log
else
echo "$current_time IP 地址:$i ping 成功了!" >>/opt/jacktian/ip.txt_ping.log
fi
done
# 输出执行了多长时间
# 获取结束时间戳
end_time=$(date +%s)
# 计算执行时间(秒)
execution_time_seconds=$((end_time - start_time))
# 将执行时间转换为分钟和秒
minutes=$((execution_time_seconds / 60))
seconds=$((execution_time_seconds % 60))
echo "执行完毕!该脚本执行时间共: $minutes 分钟 $seconds 秒"