批量ping 脚本

新接手了一个项目,10多个网段,500多机器,看自己机器可以连上多少服务器,一个个ping不符合我们的作风,因此百度了下大神的脚本,按自己的风格修改了,于是有了如下的脚本。

脚本如下:

vi ping_ip.sh
#! /bin/bash
#功能,ping文件ip.lst中的IP,成功的输出到ping_ok.lst文件,失败的输出到ping_fail.lst文件。
echo "" >ping_fail.lst
echo "" >ping_ok.lst
for i in `cat ip.lst`
do
ping=`ping -c 1 $i|grep loss|awk '{print $6}'|awk -F "%" '{print $1}'`
if [ $ping -eq 100 ];then
echo $i >>ping_fail.lst
else
echo $i >>ping_ok.lst
fi
done
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

ip文件案例

ip.lst
10.1.1.1
10.2.4.8
  • 1
  • 2
  • 3

执行方法: sh ping_ip.sh

脚本说明:

  #! /bin/bash
#功能,ping文件ip.lst中的IP,成功的输出到ping_ok.lst文件,失败的输出到ping_fail.lst文件。
echo "" >ping_fail.lst #先初始化下两个结果文件,避免多次执行的时候数据混乱问题
echo "" >ping_ok.lst
for i in `cat ip.lst` #for循环ip.lst 这个文件, 这也可以改改 ,比如 cat iplst |grep -v ^# 将 “#” 开头的行去掉。
do
ping=`ping -c 1 $i|grep loss|awk '{print $6}'|awk -F "%" '{print $1}'` #执行ping命令将ping的 结果放到变量ping 中,成功的返回的是0,失败的返回的是100
if [ $ping -eq 100 ];then #这个判断就是判断ping是不是等于100, 等于就是失败,写入到失败的文件中,否则就是OK,写入OK文件中
echo $i >>ping_fail.lst
else
echo $i >>ping_ok.lst
fi
done

最新文章

  1. 括号匹配 区间DP (经典)
  2. javaweb学习总结(二十九)——EL表达式
  3. ASP.NET操作WMI
  4. CentOS7--DNS处理模块DnsPython的简单使用
  5. TaskTracker执行map或reduce任务的过程2
  6. python数据结构(一)------序列
  7. 乐观的并发策略——基于CAS的自旋
  8. LeetCode刷题-004两个排序数组的中位数
  9. R语言学习——因子
  10. [leetcode]6. ZigZag Conversion字符串Z形排列
  11. 'sudo'不是内部或外部命令,,,,的解决办法
  12. oracle EBS grant 您不具有执行当前操作的足够权限。请与您的系统管理员联系。
  13. Tornado简介
  14. Pyhton配置CGI
  15. c++刷题(18/100)树
  16. ebay商品基本属性组合成数据表格式,可用上传到系统递交数据
  17. elasticsearch-5.1.1 安装的问题
  18. Python自定义web框架、Jinja2
  19. ssdfd
  20. Elasticsearch-PHP 搜索操作

热门文章

  1. 关于head中代码被挤到body中的问题
  2. mysql随机返回一条数据
  3. python下载站长素材免费简历模板(xpath)
  4. C# 设置桌面为父窗口
  5. ARM的发展史以及架构解析
  6. Linux 第五节 (shell脚本while循环,case,计划任务,用户及权限)
  7. IC杂记
  8. vscore 中 vim 常用快捷键
  9. ES6-moudle
  10. c语言动态库与静态库