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
剩下的代码大家都懂的<.-.>
2170

被折叠的 条评论
为什么被折叠?



