linux批量ping脚本shell
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
,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。**
脚本命令
*#! /bin/bash
for i in cat ip.txt
do
ping=ping -c 1 $i|grep loss|awk '{print $6}'|awk -F "%" '{print $1}'
if [
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
|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
剩下的代码大家都懂的<.-.>
下一篇: 开始使用 swift 的 c语言 库