免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 5876 | 回复: 15
打印 上一主题 下一主题

[文本处理] 请教一个检测网络状态的shell脚本 [复制链接]

论坛徽章:
8
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015小元宵徽章
日期:2015-03-06 15:58:18每日论坛发贴之星
日期:2015-06-08 22:20:00每日论坛发贴之星
日期:2015-06-08 22:20:00操作系统版块每日发帖之星
日期:2015-06-14 22:20:00数据库技术版块每日发帖之星
日期:2015-11-09 06:20:00数据库技术版块每日发帖之星
日期:2016-02-22 06:20:0015-16赛季CBA联赛之上海
日期:2017-01-01 23:58:53
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-07-24 00:52 |只看该作者 |倒序浏览
请教一个shell脚本,ip地址列表在ip.txt里面。写个shell脚本将ping的结果追加到到result.xls或者result.txt里。截图如下:

或者结果卸载excl也行如下:

论坛徽章:
8
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015小元宵徽章
日期:2015-03-06 15:58:18每日论坛发贴之星
日期:2015-06-08 22:20:00每日论坛发贴之星
日期:2015-06-08 22:20:00操作系统版块每日发帖之星
日期:2015-06-14 22:20:00数据库技术版块每日发帖之星
日期:2015-11-09 06:20:00数据库技术版块每日发帖之星
日期:2016-02-22 06:20:0015-16赛季CBA联赛之上海
日期:2017-01-01 23:58:53
2 [报告]
发表于 2014-07-24 00:53 |只看该作者
忘记贴图了 补充下图

QQ图片20140724004941.jpg (73.17 KB, 下载次数: 32)

QQ图片20140724004941.jpg

论坛徽章:
8
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015小元宵徽章
日期:2015-03-06 15:58:18每日论坛发贴之星
日期:2015-06-08 22:20:00每日论坛发贴之星
日期:2015-06-08 22:20:00操作系统版块每日发帖之星
日期:2015-06-14 22:20:00数据库技术版块每日发帖之星
日期:2015-11-09 06:20:00数据库技术版块每日发帖之星
日期:2016-02-22 06:20:0015-16赛季CBA联赛之上海
日期:2017-01-01 23:58:53
3 [报告]
发表于 2014-07-24 00:54 |只看该作者
或者写在excl也行如下:

3.png (65.31 KB, 下载次数: 30)

3.png

论坛徽章:
0
4 [报告]
发表于 2014-07-24 09:01 |只看该作者
try
  1. #! /bin/sh


  2. while read line;do

  3. s=`ping -c 4 $line`
  4. if [ $? -eq 0 ];then

  5. TTL=`echo $s | grep -Po '(?<=ttl=)[^ ]+' | head -1`

  6. all=`echo $s | grep -Po '(?<=min/avg/max/mdev = )[^ ]+'`
  7. MIN=`echo $all | cut -d / -f 1`
  8. AVG=`echo $all | cut -d / -f 2`
  9. MAX=`echo $all | cut -d / -f 3`
  10. LOSS=`echo $s | grep -Po '[0-9]+%'`
  11. echo $line "    "$MIN"     " $AVG "     "$MAX  "      " $LOSS


  12. else
  13. echo "LOSS "$line"     100%"


  14. fi
复制代码

论坛徽章:
8
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015小元宵徽章
日期:2015-03-06 15:58:18每日论坛发贴之星
日期:2015-06-08 22:20:00每日论坛发贴之星
日期:2015-06-08 22:20:00操作系统版块每日发帖之星
日期:2015-06-14 22:20:00数据库技术版块每日发帖之星
日期:2015-11-09 06:20:00数据库技术版块每日发帖之星
日期:2016-02-22 06:20:0015-16赛季CBA联赛之上海
日期:2017-01-01 23:58:53
5 [报告]
发表于 2014-07-24 09:47 |只看该作者
回复 4# zerostudy


    恩你这个脚本可以用,我现在把获得的数据写入了数据库里,但是我想保留每个ip的历史数据前10次
这个如何弄?截图如下:

论坛徽章:
0
6 [报告]
发表于 2014-07-24 10:11 |只看该作者
本帖最后由 zerostudy 于 2014-07-24 10:12 编辑

回复 5# zl624867243


    你是一个ip一个记录,就是同一个ip他也是会再添加一条记录,是这样吗?
若是这样的话:

建议:
表结构添加一列id号,做主键。
添加一条定时执行的sql语句,即:多长时间执行一次,delete掉,同一个ip超过10次的数据。

论坛徽章:
8
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015小元宵徽章
日期:2015-03-06 15:58:18每日论坛发贴之星
日期:2015-06-08 22:20:00每日论坛发贴之星
日期:2015-06-08 22:20:00操作系统版块每日发帖之星
日期:2015-06-14 22:20:00数据库技术版块每日发帖之星
日期:2015-11-09 06:20:00数据库技术版块每日发帖之星
日期:2016-02-22 06:20:0015-16赛季CBA联赛之上海
日期:2017-01-01 23:58:53
7 [报告]
发表于 2014-07-24 10:16 |只看该作者
回复 6# zerostudy


    恩 同一个ip也会添加记录,用sql语句可以搞定我等下去看看。这个脚本就是检测网络状态的 最后我会在php页面去读取数据库的内容,把最新的数据展现在页面上,对于ping不通的ip就告警 告警准备用py实现
谢谢了

论坛徽章:
1
双鱼座
日期:2014-08-25 19:13:11
8 [报告]
发表于 2014-07-24 13:15 |只看该作者
  1. while read line
  2. do
  3.         ping -c 4 $line|awk -F'[=\/ ]' -vip=$line '{if($0~/rtt/){min=$8;avg=$9;max=$10}if($0~/ttl/){ttl=$8}if($0~/loss/){loss=$6}}END{printf("%s\t%s\t%s\t%s\t%s\t%s\n",ip,min,avg,max,loss,ttl)}' >>result.txt
  4. done < ip.txt
复制代码

论坛徽章:
0
9 [报告]
发表于 2014-07-24 13:36 |只看该作者
zerostudy兄,能解释下,你的代码吗,我刚开始学习,谢谢

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
10 [报告]
发表于 2014-07-24 13:37 |只看该作者
回复 9# 瘦瓜


    哪里看不懂?直接问
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP