linux批量ping脚本shell
重点:本博客内容有来自网络,有来自朋友,如果涉及到了您的版权问题,请及时与本人联系
ping失败后的返回字符串
5 packets transmitted, 0 received, 100% packet loss, time 3999ms
grep
命令正解:grep (global search regular expression(RE) and print out the line
,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。
shell
脚本命令
#! /bin/bash
for i in `cat ip.txt`
do
ping=`ping -c 1 $i|grep loss|awk '{print $6}'|awk -F "%" '{print $1}' `
if [ $ping -eq 100 ];then
echo ping $i fail
else
echo ping $i ok
fi
done
分析:
for i in 'cat ip.txt'
这句话是遍历名字为ip.txt文件,并将每一行的字符串(这里是ip)逐个读出来给变量i
ping=`ping -c 1 $i|grep loss|awk '{print $6}'|awk -F "%" '{print $1}'`
ping -c 1 $i
表示只ping
一次。命令解释: -c
计数(count), 1
表示一次,$i
是ip。
|grep loss
通过管道的方式查找ping后的结果含有loss
的字符串(行数据)。
命令解释:|
管道符, grep
全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。loss
要寻找的包含字符串
|awk '{print $6}'
表示通过管道符传输过来,用awk
命令将字符串以空格进行切割成不同的行,{print $6}
输出切割后的第6行
|awk -F "%" '{print $1}'
表示将字符串以%进行切割{print $1}
输出第一行字符串
if [ $ping -eq 100 ];then
如果等于100则说明丢包
echo ping $i fail 输出 fail
剩下的代码大家都懂的<.-.>