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